@charset "UTF-8";
/*------------------------------------------------------------


  common.css


------------------------------------------------------------*/
@font-face {
    font-family: "Inter";
    src: url("../fonts/Inter-Light.woff2") format("woff2"),
         url("../fonts/Inter-Light.woff") format("woff"),
         url("../fonts/Inter-Light.ttf") format("truetype");
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Inter";
    src: url("../fonts/Inter-ExtraLight.woff2") format("woff2"),
         url("../fonts/Inter-ExtraLight.woff") format("woff"),
         url("../fonts/Inter-ExtraLight.ttf") format("truetype");
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}


/*============================================================
  reset
============================================================*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  margin-block-start: 0;
  margin-block-end: 0;
  margin-inline-start: 0;
  margin-inline-end: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, nav, section {
  display: block;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  font-size: 100%;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote::before, blockquote::after,
q::before, q::after {
  content: "";
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  background: transparent;
}

ins {
  background-color: transparent;
  color: #000;
  text-decoration: none;
}

mark {
  background-color: transparent;
  color: #000;
  font-style: normal;
  font-weight: normal;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom:1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

hr {
  display: block;
  border: 0;
  margin: 0;
  padding: 0;
}

input {
  margin: 0;
  padding: 0;
  outline: none;
  vertical-align: middle;
  font-family: inherit;
  background: none;
  border: none;
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

input[type="submit"],
input[type="button"] {
  cursor: pointer;
}

select {
  font-family: inherit;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  vertical-align: middle;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

textarea {
  font-family: inherit;
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

button {
  display: block;
  font-family: inherit;
  border: none;
  border-radius: 0;
  background: none;
  outline: none;
  margin: 0;
  padding: 0;
  vertical-align: middle;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}

button:disabled {
  cursor: default;
}

img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

strong, em, b, i, small, address {
  font-weight: normal;
  font-style: normal;
}

summary {
  display: block;
  cursor: pointer;
  outline: none;
}

summary::-webkit-details-marker {
  display: none;
}

main {
  display: block;
}


/*============================================================
  global
============================================================*/
* {
  box-sizing: border-box;
}

*:focus {
  outline: none;
}

html {
  width: 100%;
  color: var(--black);
  font-size: calc(100vw / 144); /* 0.694vw */
  text-align: left;
  background-color: var(--white);
  scroll-behavior: smooth;
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  html { font-size: calc(100vw / 144); /* 0.694vw（横幅1440pxで割った数値） */ }
}

@media (max-width: 768px) and (orientation: portrait) {
  html { font-size: calc(100vw / 48); /* 2.5vw（横幅400pxで割った数値） */ }
}

:root {
  --black: #000;
  --matteblack: #181818;
  --white: #fff;
  --gray: #888;
  --lightgray: #f8f8f8;
  --grid: 1.6rem;
  --grid-2: calc(var(--grid) * 2); /* 3.2rem / 1.6rem */
  --grid-3: calc(var(--grid) * 3); /* 4.8rem / 2.4rem */
  --grid-4: calc(var(--grid) * 4); /* 6.4rem / 3.2rem */
  --grid-5: calc(var(--grid) * 5); /* 8rem / 4rem */
  --grid-6: calc(var(--grid) * 6); /* 9.6rem / 4.8rem */
  --grid-7: calc(var(--grid) * 7); /* 11.2rem / 5.6rem */
  --grid-8: calc(var(--grid) * 8); /* 12.8rem / 6.4rem; */
  --grid-10: calc(var(--grid) * 10); /* 16rem / 8rem */
  --grid-12: calc(var(--grid) * 12); /* 19.2rem / 9.6rem */
  --grid-14: calc(var(--grid) * 14); /* 22.4rem / 11.2rem */
  --grid-16: calc(var(--grid) * 16); /* 25.6rem / 12.8rem */
  --grid-18: calc(var(--grid) * 18); /* 28.8rem / 14.4rem */
  --grid-20: calc(var(--grid) * 20); /* 32rem / 16rem */
  --grid-22: calc(var(--grid) * 22); /* 35.2rem / 17.6rem */
  --grid-24: calc(var(--grid) * 24); /* 38.4rem / 19.2rem */
  --grid-26: calc(var(--grid) * 26); /* 41.6rem / 20.8rem */
  --grid-28: calc(var(--grid) * 28); /* 44.8rem / 22.4rem */
  --grid-30: calc(var(--grid) * 30); /* 48rem / 24rem */
  --grid-32: calc(var(--grid) * 32); /* 51.2rem / 25.6rem */
  --grid-34: calc(var(--grid) * 34); /* 54.4rem / 27.2rem */
  --grid-36: calc(var(--grid) * 36); /* 57.6rem / 28.8rem */
  --grid-38: calc(var(--grid) * 38); /* 60.8rem / 30.4rem */
  --grid-40: calc(var(--grid) * 40); /* 64rem / 32rem */
  --grid-42: calc(var(--grid) * 42); /* 67.2rem / 33.6rem */
  --grid-44: calc(var(--grid) * 44); /* 70.4rem / 35.2rem */
  --grid-46: calc(var(--grid) * 46); /* 73.6rem / 36.8rem */
  --grid-48: calc(var(--grid) * 48); /* 73.6rem */
  --grid-52: calc(var(--grid) * 52); /* 83.2rem; */
  --grid-52: calc(var(--grid) * 54); /* 86.4rem; */
  --grid-52: calc(var(--grid) * 56); /* 89.2rem; */
  --grid-58: calc(var(--grid) * 58); /* 92.8rem; */
  --grid-60: calc(var(--grid) * 60); /* 96rem; */
  --grid-62: calc(var(--grid) * 62); /* 99.2rem; */
  --grid-64: calc(var(--grid) * 64); /* 102.4rem; */
  --grid-66: calc(var(--grid) * 66); /* 105.6rem; */
  --grid-68: calc(var(--grid) * 68); /* 108.8rem; */
  --grid-70: calc(var(--grid) * 70); /* 112rem; */
  --grid-72: calc(var(--grid) * 72); /* 115.2rem; */
  --grid-74: calc(var(--grid) * 74); /* 118.4rem; */
  --grid-76: calc(var(--grid) * 76); /* 121.6rem; */
  --grid-78: calc(var(--grid) * 78); /* 124.8rem; */
  --grid-80: calc(var(--grid) * 80); /* 128rem; */
  --grid-82: calc(var(--grid) * 82); /* 131.2rem; */
  --grid-84: calc(var(--grid) * 84); /* 134.4rem; */
  --grid-86: calc(var(--grid) * 86); /* 137.6rem; */
  --grid-88: calc(var(--grid) * 88); /* 140.8rem; */
}

@media (max-width: 768px) and (orientation: portrait) {
  :root {
    --grid: 0.8rem;
  }
}

body {
  width: 100%;
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",
               "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Yu Gothic UI",
               "メイリオ", "Meiryo", "Meiryo UI", sans-serif;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "palt" 1;
  font-variant-ligatures: no-common-ligatures;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  overflow: auto;
  position: relative;
}

html.paused,
html.paused body {
  overflow: hidden;
}

main {
  width: 100%;
  padding-top: 18.4rem;
  overflow: hidden;
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  #work-single main {
    padding-top: 0;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  main {
    padding-top: var(--grid-16);
  }
}


/*============================================================
  a
============================================================*/
a {
  color: var(--black);
  outline: 0;
  text-decoration: none;
}

a[href] { cursor: pointer; }
a[href^="tel"]{ color: inherit; }


/*============================================================
  text
============================================================*/
strong,
em,
span,
b,
sup {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;
  letter-spacing: inherit;
  line-height: inherit;
}

sup {
  font-size: 1rem !important;
  font-weight: normal !important;
}


/*  font family
--------------------*/
.ff-sans-serif {
  font-family: "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro",
               "游明朝体", YuMincho, "游明朝", "Yu Mincho", serif !important;
}

.ff-sans {
  font-family: "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",
               "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Yu Gothic UI",
               "メイリオ", "Meiryo", "Meiryo UI", sans-serif !important;
}

.ff-inter {
  font-family: "Inter", sans-serif;
}


/*  weight
--------------------*/
.fw-light { font-weight: lighter; }
.fw-normal { font-weight: normal; }
.fw-bold { font-weight: bold; }


/*  br
--------------------*/
@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  br.sw {
    display: none !important;
    font-size: 0 !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  br.lw {
    display: none !important;
    font-size: 0 !important;
  }
}

/*  none
--------------------*/
.none {
  display: none !important;
  font-size: 0 !important;
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  .none-lw {
    display: none !important;
    font-size: 0 !important;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .none-sw {
    display: none !important;
    font-size: 0 !important;
  }
}

/*  hidden
--------------------*/
.hidden {
  display: block;
  width: 0;
  height: 0;
  line-height: 0;
  overflow: hidden;
  padding: 0 !important;
  margin: 0 !important;
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  .hidden-lw {
    display: block;
    width: 0;
    height: 0;
    line-height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .hidden-sw {
    display: block;
    width: 0;
    height: 0;
    line-height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
  }
}


/*============================================================
  button-link
============================================================*/
.button-link {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  height: 6.4rem;
  font-size: 1.52rem;
  letter-spacing: 0.02em;
  outline: 1px solid;
  border-radius: 3.2rem;
  padding: 0 3.2rem;
}

.button-link.ff-inter {
  font-size: 1.68rem;
}

.button-link[disabled] {
  opacity: 0.24;
  cursor: default;
}

.button-link .icon-arrow {
  width: 1.6rem;
  height: auto;
  margin-top: -0.16rem;
}

.button-link.cl-blk {
  color: var(--black);
  outline-color: var(--black);
}

.button-link.cl-blk .icon-arrow {
  stroke: var(--black);
}

.button-link.cl-wht {
  color: var(--white);
  outline-color: var(--white);
}

.button-link.cl-wht .icon-arrow {
  stroke: var(--white);
}

.button-link.button-prev .icon-arrow {
  transform: scaleX(-1);
}

@media (hover: hover) {
  .button-link.cl-blk:not([disabled]):hover {
    color: var(--white);
    background-color: var(--black);
  }

  .button-link.cl-blk:not([disabled]):hover .icon-arrow {
    stroke: var(--white);
  }

  .button-link.cl-wht:not([disabled]):hover {
    color: var(--black);
    background-color: var(--white);
  }

  .button-link.cl-wht:not([disabled]):hover .icon-arrow {
    stroke: var(--black);
  }
}


/*============================================================
  button-accordion
============================================================*/
.button-accordion {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  height: 4rem;
  color: var(--gray);
  font-size: 1.52rem;
  letter-spacing: 0.02em;
  outline: 1px solid var(--gray);
  border-radius: 8rem;
  padding: 0 1.6rem;
}

.button-accordion[disabled] {
  opacity: 0.24;
  cursor: default;
}

.button-accordion .icon-accordion {
  stroke: var(--gray);
  width: 1.4rem;
  height: 1.4rem;
}

@media (hover: hover) {
  .button-accordion:not([disabled]):hover {
    color: var(--white);
    background-color: var(--black);
    outline-color: transparent;
  }

  .button-accordion:not([disabled]):hover .icon-accordion {
    stroke: var(--white);
  }
}


/*============================================================
  label
============================================================*/
.label-category {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  height: 3.6rem;
  color: var(--white);
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  background-color: var(--black);
  padding: 0.08em 0.64em;
  white-space: nowrap;
}

.label-tag {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  height: 3.6rem;
  color: var(--black);
  font-size: 1.6rem;
  letter-spacing: 0.02em;
  outline: 1px solid #c8c8c8;
  outline-offset: -1px;
  padding: 0.08em 0.64em;
  white-space: nowrap;
}

@media (hover: hover) {
  a.label-category:hover,
  a.label-tag:hover {
    opacity: 0.24;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .label-category {
    font-size: 1.44rem;
  }

  .label-tag {
    font-size: 1.44rem;
  }
}


/*============================================================
  h-title
============================================================*/
.h-title-page {
  font-size: 6.4rem;
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin-block: -0.1em;
}

.h-title-page-en {
  font-size: 12rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-block: -0.1em;
}

.h-title-page-archive {
  font-size: 2.4rem;
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin-block: -0.1em;
}

.h-title-section {
  font-size: 4rem;
  letter-spacing: 0.02em;
  line-height: 1.2;
  margin-block: -0.1em;
}

.h-title-section-en {
  font-size: 12rem;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-block: -0.1em;
}

@media (max-width: 768px) and (orientation: portrait) {
  .h-title-page {
    font-size: 4rem;
  }

  .h-title-page-en {
    font-size: 7.2rem;
  }

  .h-title-section {
    font-size: 3.2rem;
  }

  .h-title-section-en {
    font-size: 6.4rem;
  }
}


/*============================================================
  text-link
============================================================*/
.text-link {
  text-decoration: underline;
  text-decoration-thickness: 0.8px;
  text-underline-offset: 0.32em;
}

@media (hover: hover) {
  .text-link:hover {
    text-decoration-color: transparent;
  }
}


/*============================================================
  text-box
============================================================*/
.text-box {
  display: inline-block;
  border-radius: 0.8rem;
  padding: 0.48em 0.56em;
}

.text-box.cl-blk {
  color: var(--white);
  background-color: var(--black);
}

.text-box.cl-wht {
  color: var(--black);
  background-color: var(--white);
}

.text-box.cl-blk.frame {
  color: var(--black);
  background: none;
  border: 1px solid var(--black);
}

.text-box.cl-wht.frame {
  color: var(--white);
  background: none;
  border: 1px solid var(--white);
}


/*============================================================
  image-piece
============================================================*/
.image-piece {
  display: inline-block;
  border-radius: 40rem;
  overflow: hidden;
  position: relative;
}

.image-piece::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.04);
  position: absolute;
  left: 0;
  top: 0;
}

.image-piece .picture {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/*============================================================
  p-alert
============================================================*/
.p-alert {
  width: var(--grid-82);
  color: var(--black);
  font-size: 1.52rem;
  letter-spacing: 0.02em;
  text-align: center;
  padding: var(--grid-2) 0;
  margin: 0 auto;
}

@media (max-width: 768px) and (orientation: portrait) {
  .p-alert {
    width: auto;
    margin: 0 var(--grid-2);
  }
}


/*============================================================
  ul-notes
============================================================*/
.ul-notes {
  padding-left: 1.2em;
}

.ul-notes > li {
  list-style-position: outside;
  text-indent: -1.2em;
}

.ul-notes > li::before {
  content:"※";
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;
  letter-spacing: inherit;
  line-height: inherit;
}

.ul-notes > li + li {
  margin-top: 0.8em;
}


/*============================================================
  dl-label
============================================================*/
.dl-label {
  display: flex;
  flex-direction: column;
  gap: calc(var(--grid) * 1.5);
}

.dl-label > dt {
  font-size: 2.4rem;
}

.dl-label > dd {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}


/*============================================================
  ul-label
============================================================*/
.ul-label {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 1.2rem;
}

@media (max-width: 768px) and (orientation: portrait) {
  .ul-label {
    gap: 0.8rem;
  }
}


/*============================================================
  ul-point
============================================================*/
.ul-point {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: start;
  justify-content: left;
  column-gap: var(--grid-8);
  row-gap: var(--grid-6);
  width: 100%;
  counter-reset: item;
}

.ul-point.column-2 > li {
  width: calc((100% - var(--grid-8)) / 2);
}

.ul-point.column-3 > li {
  width: calc((100% - var(--grid-16)) / 3);
}

.ul-point > li .number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--grid-2);
  height: var(--grid-2);
  color: var(--white);
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  text-align: center;
  background-color: var(--black);
  border-radius: var(--grid-2);
  overflow: hidden;
}

@media (max-width: 768px) and (orientation: portrait) {
  .ul-point {
    column-gap: var(--grid-2);
  }

  .ul-point.column-2 > li {
    width: calc((100% - var(--grid-2)) / 2);
  }

  .ul-point.column-3 > li {
    width: calc((100% - var(--grid-2)) / 2);
  }

   .ul-point > li .number {
    width: var(--grid-3);
    height: var(--grid-3);
    font-size: 1.6rem;
    border-radius: var(--grid-6);
  }
}


/*============================================================
  item-point
============================================================*/
.item-point {
  display: flex;
  flex-direction: column-reverse;
  gap: var(--grid-2);
}

.item-point .div-item-point-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
}

.item-point .div-item-point-1 .h-catch-item-point {
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  line-height: 1.44;
}

.item-point .div-item-point-1 .p-description-item-point {
  font-size: 1.84rem;
  letter-spacing: 0.02em;
  line-height: 1.6;
}

.item-point .div-item-point-2 .figure-item-point {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: var(--grid);
  overflow: hidden;
}

.item-point .div-item-point-2 .figure-item-point img.picture {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 768px) and (orientation: portrait) {
  .item-point {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--grid-2);
  }

  .item-point .div-item-point-1 .h-catch-item-point {
    font-size: 2.4rem;
  }

  .item-point .div-item-point-1 .h-catch-item-point br {
    display: none;
  }

  .item-point .div-item-point-1 .p-description-item-point {
    font-size: 1.6rem;
  }
}


/*============================================================
  item-work
============================================================*/
.item-work {
  display: flex;
  align-items: center;
  width: 100%;
  aspect-ratio: 4 / 3;
  position: relative;
  z-index: 0;
  overflow: hidden;
}

.item-work .div-item-work {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width: var(--grid-82);
  padding: var(--grid-4) 0;
  margin: 0 auto;
}

.item-work:nth-of-type(even) .div-item-work {
  flex-direction: row-reverse;
}

.item-work .div-item-work .div-item-work-1 {
  display: flex;
  flex-direction: column;
  gap: var(--grid-2);
  width: var(--grid-22);
}

.item-work .div-item-work .div-item-work-1 .p-title-item-work-en {
  font-size: 6.4rem;
  line-height: 1.12;
}

.item-work .div-item-work .div-item-work-1 .h-title-item-work {
  font-size: 2rem;
  letter-spacing: 0.02em;
}

.item-work .div-item-work .div-item-work-1 .h-catch-item-work {
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  line-height: 1.44;
}

.item-work .div-item-work .div-item-work-1 .p-description-item-work {
  font-size: 2rem;
  letter-spacing: 0.02em;
  line-height: 1.6;
}

.item-work .div-item-work .div-item-work-2 {
  width: var(--grid-28);
}

.item-work .div-item-work .div-item-work-2 .figure-item-work {
  width: 100%;
  position: relative;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-main {
  display: block;
  border: 0.24rem solid #222;
  border-radius: var(--grid-2);
  overflow: hidden;
  margin: auto;
  position: relative;
  z-index: 1;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-main {
  width: var(--grid-16);
  aspect-ratio: 1 / 2;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-main {
  width: var(--grid-28);
  aspect-ratio: 1.4 / 1;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-main .picture {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-piece {
  position: absolute;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-piece.piece-1 {
  width: calc(var(--grid) * 10);
  aspect-ratio: 2 / 1;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-piece.piece-2 {
  width: calc(var(--grid) * 6);
  aspect-ratio: 4 / 3;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-piece.piece-3 {
  width: calc(var(--grid) * 6);
  aspect-ratio: 16 / 9;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work .image-piece.piece-4 {
  width: calc(var(--grid) * 8);
  aspect-ratio: 24 / 1;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-piece.piece-1 {
  left: 32%;
  bottom: -24%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-piece.piece-2 {
  left: -8%;
  top: 48%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-piece.piece-3 {
  left: 16%;
  top: -20%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-piece.piece-4 {
  right: 0;
  bottom: 20%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-piece.piece-1 {
  left: 12%;
  bottom: -32%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-piece.piece-2 {
  right: 6.4%;
  top: -40%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-piece.piece-3 {
  right: 32%;
  bottom: -64%;
}

.item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-piece.piece-4 {
  left: -8%;
  top: -20%;
}

.item-work .p-image-item-work {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}

.item-work .p-image-item-work::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.64);
  position: absolute;
  left: 0;
  top: 0;
}

.item-work .p-image-item-work img.picture {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 769px) and (orientation: portrait) {
  .item-work .p-image-item-work img.picture.parallax {
    width: 108%;
    height: 108%;
    margin-left: -4%;
    margin-top: -4%;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .item-work {
    display: flex;
    align-items: center;
    aspect-ratio: auto;
  }

  .item-work .div-item-work {
    flex-direction: column-reverse;
    align-items: initial;
    justify-content: initial;
    gap: var(--grid-6);
    width: auto;
    padding: var(--grid-6) var(--grid-2);
  }

  .item-work:nth-of-type(even) .div-item-work {
    flex-direction: column-reverse;
  }

  .item-work .div-item-work .div-item-work-1 {
    gap: var(--grid-2);
    width: 100%;
  }

  .item-work .div-item-work .div-item-work-1 .p-title-item-work-en {
    font-size: 4.8rem;
  }

  .item-work .div-item-work .div-item-work-1 .p-title-item-work-en br {
    display: none;
  }

  .item-work .div-item-work .div-item-work-1 .h-title-item-work {
    font-size: 1.84rem;
  }

  .item-work .div-item-work .div-item-work-1 .h-catch-item-work {
    font-size: 2.4rem;
  }

  .item-work .div-item-work .div-item-work-1 .h-catch-item-work br {
    display: none;
  }

  .item-work .div-item-work .div-item-work-1 .p-description-item-work {
    font-size: 1.84rem;
  }

  .item-work .div-item-work .div-item-work-2 {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--grid-36);
    aspect-ratio: 3 / 4;
    margin: 0 auto;
  }

  .item-work .div-item-work .div-item-work-2 .figure-item-work.phone .image-main {
    width: var(--grid-18);
  }

  .item-work .div-item-work .div-item-work-2 .figure-item-work.tablet .image-main {
    width: var(--grid-36);
  }
}


/*============================================================
  article-work-item
============================================================*/
.article-work-item {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  gap: var(--grid-2);
}

.article-work-item .div-article-work-item-1 {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: var(--grid);
  height: var(--grid-10);
  padding-right: var(--grid-3);
  position: relative;
}

.article-work-item .div-article-work-item-1 .ul-label {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.article-work-item .div-article-work-item-1 .ul-tag {
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  width: 100%;
  color: var(--gray);
  font-size: 1.36rem;
  text-overflow: ellipsis;
  overflow: hidden;
}

.article-work-item .div-article-work-item-1 .ul-tag > li {
  display: inline;
}

.article-work-item .div-article-work-item-1 .ul-tag > li + li {
  margin-left: 0.8rem;
}

.article-work-item .div-article-work-item-1 .ul-tag .text-tag {
  color: var(--gray);
  font-size: 1.36rem;
}

.article-work-item .div-article-work-item-1 .h-title {
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  max-height: calc((3.2rem * 2) + (3.2rem * 1.2));
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  line-height: 1.2;
  overflow: hidden;
}

.article-work-item .div-article-work-item-1 .icon-arrow {
  stroke: var(--black);
  width: 1.6rem;
  height: auto;
  position: absolute;
  right: 0;
  bottom: 0;
}

.article-work-item .div-article-work-item-2 .figure-item-pickup {
  width: var(--grid-10);
  height: var(--grid-10);
  aspect-ratio: 1 / 1;
}

.article-work-item .div-article-work-item-2 .figure-item-pickup .picture {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

@media (max-width: 768px) and (orientation: portrait) {
  .article-work-item {
    gap: var(--grid-2);
  }

  .article-work-item .div-article-work-item-1 {
    display: flex;
    flex-direction: column;
    gap: var(--grid);
    height: var(--grid-16);
    padding-right: var(--grid-3);
    position: relative;
  }

  .article-work-item .div-article-work-item-1 .ul-label .text-tag {
    font-size: 1.28rem;
  }

  .article-work-item .div-article-work-item-1 .h-title {
    max-height: calc((2.4rem * 2) + (2.4rem * 1.2));
    font-size: 2.4rem;
  }
}


/*============================================================
  wp-pager
============================================================*/
.wp-pager {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  margin: 3.2rem auto;
}

.wp-pager .page-numbers {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  width: 4.8rem;
  height: 4.8rem;
  color: var(--black);
  font-family: "Inter", sans-serif;
  font-size: 2rem;
  white-space: nowrap;
  outline: 1px solid var(--black);
  border-radius: 0.8rem;
  position: relative;
  overflow: hidden;
}

.wp-pager .page-numbers.current {
  color: var(--white);
  background-color: var(--black);
  cursor: default;
}

.wp-pager .page-numbers.dots {
  outline: none;
}

.wp-pager .page-numbers.next,
.wp-pager .page-numbers.prev {
  width: 8rem;
  font-size: 1.84rem;
}

.wp-pager .page-numbers.next .icon-arrow,
.wp-pager .page-numbers.prev .icon-arrow {
  stroke: var(--black);
  width: 1.6rem;
  height: auto;
  margin-top: -0.08rem;
}

.wp-pager .page-numbers.prev .icon-arrow {
  transform: scaleX(-1);
}

@media (hover: hover) {
  .wp-pager .page-numbers:not(.current):not(.dots):hover {
    color: var(--white);
    background-color: var(--black);
  }

  .wp-pager .page-numbers:not(.current):not(.dots):hover .icon-arrow {
    stroke: var(--white);
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  .wp-pager .page-numbers.next,
  .wp-pager .page-numbers.prev {
    width: 6.4rem;
  }

  .wp-pager .page-numbers.next .icon-arrow,
  .wp-pager .page-numbers.prev .icon-arrow {
    display: none;
  }
}


/*============================================================
  header
============================================================*/
#header-global {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  justify-content: space-between;
  width: 100%;
  height: 18.4rem;
  background-color: var(--white);
  padding: var(--grid-2) 0;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 24;
}

#header-global .logo-x7 {
  display: block;
  margin-left: var(--grid-2);
}

#header-global .logo-x7 .logo {
  fill: var(--black);
  width: auto;
  height: 12rem;
}

#header-global .logo-x7 .logotype {
  fill: var(--black);
  width: auto;
  height: 8rem;
  display: none;
}

#header-global .nav-header {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-end;
  gap: var(--grid-2);
  width: auto;
  margin-right: var(--grid-2);
}

#header-global .nav-header .ul-menu {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--grid-2);
}

#header-global .nav-header .ul-menu > li {
  display: flex;
  flex-direction: row;
  align-items: center;
  height: var(--grid-3);
}

#header-global .nav-header .ul-menu > li.current {
  background-color: var(--lightgray);
  border-radius: var(--grid-2);
  padding: 0 calc(var(--grid) * 1.5);
}

#header-global .nav-header .ul-menu > li > a {
  color: var(--black);
  font-size: 2.4rem;
  white-space: nowrap;
}

#header-global .nav-header .ul-anchor {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
}

#header-global .nav-header .ul-anchor > li + li {
  margin-left: var(--grid);
}

#header-global .nav-header .ul-anchor::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 2rem;
  background-color: var(--black);
  margin: 0 var(--grid);
  opacity: 0.24;
}

#header-global .nav-header .ul-anchor > li > a {
  font-size: 1.6rem;
  letter-spacing: 0.04em;
}

#header-global .nav-header .button-contact {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  height: var(--grid-4);
  color: var(--white);
  font-size: 2.24rem;
  background-color: var(--black);
  border-radius: var(--grid-2);
  padding: 0 2.4rem 0 2.8rem;
}

#header-global .nav-header .button-contact .icon-arrow {
  stroke: var(--white);
  width: 1.6rem;
  height: auto;
}

#charm-header .input-menu {
  display: none;
}

#header-global .button-menu {
  display: none;
}

@media (hover: hover) {
  #header-global .nav-header .ul-menu a:hover {
    opacity: 0.24;
  }

  #header-global .nav-header .button-contact:hover {
    color: var(--black);
    background-color: var(--white);
    outline: 1px solid var(--black);
  }

  #header-global .nav-header .button-contact:hover .icon-arrow {
    stroke: var(--black);
  }

  #work-single #header-global:not(.floating) .nav-header .button-contact:hover {
    color: var(--white);
    background-color: transparent;
    outline: 1px solid var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .button-contact:hover .icon-arrow {
    stroke: var(--white);
  }
}

@media (orientation: landscape), (min-width: 769px) and (orientation: portrait) {
  #header-global.floating {
    align-items: center;
    height: 8rem;
    position: fixed;
    background-color: rgba(255, 255, 255, 0.96);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
  }

  #header-global.floating .logo-x7 {
    margin-left: var(--grid);
  }

  #header-global.floating .logo-x7 .logo {
    height: 6.4rem;
    display: none;
  }

  #header-global.floating .logo-x7 .logotype {
    height: 5.6rem;
    display: block;
  }

  #header-global .nav-header {
    margin-right: var(--grid);
  }

  #header-global.floating .nav-header .button-contact {
    height: 4.8rem;
  }

  #work-single #header-global:not(.floating) {
    background-color: transparent;
  }

  #work-single #header-global:not(.floating) .logo-x7 .logo {
    fill: var(--white);
  }

  #work-single #header-global:not(.floating) .logo-x7 .logotype {
    fill: var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .ul-menu > li.current {
    background-color: transparent;
    outline: 1px solid var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .ul-menu > li > a {
    color: var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .ul-anchor::before {
    background-color: var(--white);
    opacity: 0.4;
  }

  #work-single #header-global:not(.floating) .nav-header .ul-anchor > li > a {
    color: var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .button-contact {
    color: var(--black);
    background-color: var(--white);
  }

  #work-single #header-global:not(.floating) .nav-header .button-contact .icon-arrow {
    stroke: var(--black);
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #header-global {
    height: var(--grid-16);
    background-color: rgba(255, 255, 255, 0.96);
    -webkit-backdrop-filter: blur(8px);
    backdrop-filter: blur(8px);
    padding: var(--grid-2) 0;
  }

  #header-global .logo-x7 {
    display: block;
    margin-left: var(--grid-2);
  }

  #header-global .logo-x7 .logo {
    height: var(--grid-12);
  }

  #header-global .logo-x7 .logotype {
    height: var(--grid-6);
    display: none;
  }

  #header-global.floating {
    height: var(--grid-10);
    position: fixed;
  }

  #header-global.floating .logo-x7 .logo {
    display: none;
  }

  #header-global.floating .logo-x7 .logotype {
    display: block;
  }

  #header-global .nav-header {
    display: flex;
    flex-direction: column;
    gap: var(--grid-4);
    width: 100%;
    background-color: var(--white);
    padding: var(--grid-16) var(--grid-2) var(--grid-4);
    margin: auto;
    position: absolute;
    left: -100%;
    top: 0;
    z-index: -1;
  }

  #header-global.floating .nav-header {
    padding-top: var(--grid-10);
  }

  #header-global .nav-header .ul-menu {
    flex-direction: column;
    align-items: center;
    gap: var(--grid-4);
    width: 100%;
  }

  #header-global .nav-header .ul-menu > li {
    flex-direction: column;
    gap: var(--grid-2);
    height: auto;
    width: 100%;
  }

  #header-global .nav-header .ul-menu > li.current {
    padding: var(--grid-2);
  }

  #header-global .nav-header .ul-anchor {
    display: flex;
    flex-direction: column;
    gap: var(--grid-2);
    margin-top: var(--grid);
  }

  #header-global .nav-header .ul-anchor > li + li {
    margin-left: 0;
  }

  #header-global .nav-header .ul-anchor::before {
    display: none;
  }

  #header-global .nav-header .button-contact {
    width: var(--grid-28);
    height: var(--grid-8);
    border-radius: var(--grid-8);
  }

  #header-global .nav-header .button-contact .icon-arrow {
    stroke: var(--white);
    width: 1.6rem;
    height: auto;
  }

  #header-global .button-menu {
    display: block;
    width: var(--grid-6);
    height: var(--grid-6);
    margin-right: var(--grid-2);
    position: relative;
    z-index: 1;
  }

  #header-global .button-menu::before,
  #header-global .button-menu::after {
    content: "";
    display: block;
    width: var(--grid-6);
    height: 1px;
    background-color: var(--black);
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
  }

  #header-global .button-menu::before {
    transform: translateY(-0.32rem);
  }

  #header-global .button-menu::after {
    transform: translateY(0.32rem);
  }

  #header-global .input-menu:checked ~ .button-menu::before {
    transform: rotate(45deg);
  }

  #header-global .input-menu:checked ~ .button-menu::after {
    transform: rotate(-45deg);
  }

  #header-global .input-menu:checked ~ .nav-header {
    left: 0;
  }
}


/*============================================================
  footer-global
============================================================*/
#footer-global {
  background-color: var(--white);
  position: relative;
  z-index: 0;
}

#footer-global .div-footer-global-1 {
  width: 100%;
  height: var(--grid-6);
  border-bottom: 1px solid #ccc;
}

#footer-global .div-footer-global-1 .nav-footer {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  width:var(--grid-82);
  height: 100%;
  margin: 0 auto;
}

#footer-global .div-footer-global-1 .ul-breadcrumbs {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  justify-content: left;
  gap: 0.8rem;
}

#footer-global .div-footer-global-1 .ul-breadcrumbs > li {
  font-family: "Inter", sans-serif;
  font-size: 1.6rem;
}

#footer-global .div-footer-global-1 .ul-breadcrumbs > li + li::before {
  content: ">";
  color: inherit;
  font-family: "Inter";
  font-size: 1.28rem;
  margin-right: 0.8rem;
  vertical-align: 8%;
}

#footer-global .div-footer-global-1 .ul-breadcrumbs > li > a {
  color: inherit;
  font-size: inherit;
  letter-spacing: inherit;
}

#footer-global .div-footer-global-1 .button-pagetop {
  width: var(--grid-3);
  height: var(--grid-3);
  padding: 0;
}

#footer-global .div-footer-global-1 .button-pagetop .icon-arrow {
  transform: rotate(-90deg);
}

#footer-global .div-footer-global-2 {
  width: var(--grid-82);
  padding: var(--grid-4) 0;
  margin: 0 auto;
}

#footer-global .div-footer-global-2 .div-contact {
  display: flex;
  flex-direction: column;
  gap: var(--grid);
  width: var(--grid-34);
  margin-left: auto;
}

#footer-global .div-footer-global-2 .div-contact .div-heading {
  display: flex;
  flex-direction: column-reverse;
  gap: var(--grid);
}

#footer-global .div-footer-global-2 .div-contact .div-heading .h-title {
  display: flex;
  align-items: baseline;
  flex-wrap: nowrap;
  gap: var(--grid);
  font-size: 11.2rem;
  letter-spacing: -0.02em;
  margin-top: -0.04em;
}

#footer-global .div-footer-global-2 .div-contact .div-heading .h-title .image-piece {
  height: 8rem;
}

#footer-global .div-footer-global-2 .div-contact .div-heading .h-catch {
  font-size: 2.4rem;
  letter-spacing: 0.02em;
  line-height: 1.6;
}

#footer-global .div-footer-global-3 {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: left;
  gap: var(--grid-2);
  width: var(--grid-82);
  height: var(--grid-6);
  margin: 0 auto;
}

#footer-global .div-footer-global-3 .ul-menu {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: var(--grid-2);
}

#footer-global .div-footer-global-3 .ul-menu > li > a {
  font-size: 2.4rem;
  white-space: nowrap;
}

#footer-global .div-footer-global-3 .link-policy {
  font-size: 1.52rem;
}

#footer-global .div-footer-global-3 .small-copyright {
  font-size: 1.28rem;
}

@media (hover: hover) {
  #footer-global .div-footer-global-1 .ul-breadcrumbs > li > a[href]:hover {
    opacity: 0.24;
  }
  
  #footer-global .div-footer-global-3 .ul-menu > li > a:hover {
    opacity: 0.24;
  }

  #footer-global .div-footer-global-3 .link-policy:hover {
    opacity: 0.24;
  }
}

@media (max-width: 768px) and (orientation: portrait) {
  #footer-global .div-footer-global-1 {
    height: var(--grid-8);
  }

  #footer-global .div-footer-global-1 .nav-footer {
    width: auto;
    margin: 0 var(--grid-2);
  }

  #footer-global .div-footer-global-1 .button-pagetop {
    width: var(--grid-4);
    height: var(--grid-4);
  }

  #footer-global .div-footer-global-2 {
    width: auto;
    padding: var(--grid-4) 0;
    margin: 0 var(--grid-2);
  }

  #footer-global .div-footer-global-2 .div-contact {
    gap: var(--grid-2);
    width: 100%;
    align-items: center;
  }

  #footer-global .div-footer-global-2 .div-contact .div-heading {
    display: flex;
    flex-direction: column-reverse;
    gap: var(--grid-2);
  }

  #footer-global .div-footer-global-2 .div-contact .div-heading .h-title {
    font-size: 6.4rem;
    justify-content: center;
  }

  #footer-global .div-footer-global-2 .div-contact .div-heading .h-title .image-piece {
    height: 5.6rem;
  }

  #footer-global .div-footer-global-2 .div-contact .div-heading .h-catch {
    width: auto;
    font-size: 1.84rem;
    line-height: 1.44;
  }

  #footer-global .div-footer-global-2 .div-contact .div-heading .h-catch br {
    display: none;
  }

  #footer-global .div-footer-global-3 {
    flex-direction: column;
    align-items: center;
    width: auto;
    height: auto;
    padding: var(--grid-2) 0 var(--grid-4);
    margin: 0 var(--grid-2);
  }

  #footer-global .div-footer-global-3 .ul-menu {
    width: 100%;
    justify-content: center;
  }
}



