@charset "UTF-8";

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}
html {
  line-height: 1;
}
ol, ul {
  list-style: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
q, blockquote {
  quotes: none;
}
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}
a {
  color: var(--color-black);
  text-decoration: none;
}
a img {
  border: none;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}
img {
  vertical-align: bottom;
  max-width: 100%;
}
iframe {
  max-width: 100%;
}


:root {
  --color-black: #000;
  --color-white: #f9f9f9;
  --color-gray: #eee;
  --color-blue: #0000b6;
  --font-jp: "Tazugane Gothic", "たづがね角ゴシック", "MT たづがね角ゴシック StdN", "Noto Sans JP", sans-serif;
  --font-en: "Neue Frutiger", "Frutiger Neue LT Pro", "Open Sans", sans-serif;
  --font-size-base: min(1.33vw, 16px);
  --font-size-m: min(1.5vw, 18px);
  --font-size-s: min(1.17vw, 14px);
  --font-size-xs: min(1vw, 12px);
  --content-width: 85.5vw;
  --content-width-noR: calc(100% + var(--full-contents-padding) + 10px);
  --header-height-responsive: 7.08vw;
  --header-height-max: 85px;
  --header-height: min(var(--header-height-responsive), var(--header-height-max));
  --margin-05: min(0.42vw, 5px);
  --margin-10: min(0.83vw, 10px);
  --margin-15: min(1.25vw, 15px);
  --margin-20: min(1.67vw, 20px);
  --margin-25: min(2.08vw, 25px);
  --margin-30: min(2.5vw, 30px);
  --margin-35: min(2.92vw, 35px);
  --margin-40: min(3.33vw, 40px);
  --margin-50: min(4.17vw, 50px);
  --margin-60: min(5vw, 60px);
  --margin-70: min(5.83vw, 70px);
  --margin-80: min(6.67vw, 80px);
  --margin-90: min(7.5vw, 90px);
  --margin-100: min(8.33vw, 100px);
  --full-contents-padding: min(2.42vw, 29px);
  --section-padding: min(9.35vw, 95px);
  --main-border-radius: min(0.33vw, 4px);
  --main-easing: cubic-bezier(.165,.84,.44,1);
  --hover-transition: 800ms var(--main-easing);
}

body {
  background-color: var(--color-white);
  color: var(--color-black);
  font-family: var(--font-jp);
  font-size: var(--font-size-base);
  font-weight: 400;
  line-height: 1;
  overflow-wrap: anywhere;
}

#header {
  position: fixed;
  top: 0;
  left: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100vw;
  height: var(--header-height-responsive);
  max-height: var(--header-height-max);
  background-color: var(--color-white);
  padding: 0 var(--full-contents-padding);
  box-sizing: border-box;
  transition: background-color 300ms linear;
  z-index: 2;
}
#header.active {
  background-color: var(--color-black);
}
#header.active a {
  color: var(--color-white);
}
#header .logo {
  font-size: 0;
}
#header .logo svg {
  width: 10.42vw;
  max-width: 125px;
  height: 2.33vw;
  max-height: 28px;
  fill: var(--color-black);
}
#header.active .logo svg {
  fill: var(--color-white);
}
#header .gnavi {
  display: flex;
  align-items: center;
  column-gap: min(2.58vw, 31px);
}
#header .menu {
  font-family: var(--font-en);
}
#header .menu > ul {
  display: flex;
  align-items: center;
  column-gap: min(2.25vw, 27px);
}
#header .menu > ul > li {
  font-size: var(--font-size-xs);
}
#header .menu > ul > li > a {
  position: relative;
  white-space: nowrap;
}
#header .menu > ul > li:not(.search) > a::after {
  content: "";
  position: absolute;
  bottom: calc(var(--margin-05) - var(--margin-10));
  left: 0;
  width: 0%;
  height: 2px;
  background-color: var(--color-blue);
  transition: width var(--hover-transition);
}
#header .menu > ul > li.active > a::after {
  width: 100%;
}
@media (hover: hover) {
  #header .menu > ul > li:not(.search) > a:hover::after {
    width: 100%;
  }
}
#header .menu > ul > li.search svg {
  width: 1vw;
  max-width: 12px;
  height: 1vw;
  max-height: 12px;
  fill: var(--color-black);
}
#header.active .menu > ul > li.search svg {
  fill: var(--color-white);
}
#header .menu_child {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  padding: calc(min(6.17vw, 74px) / 2) var(--full-contents-padding) min(6.17vw, 74px);
  background-color: var(--color-black);
  box-sizing: border-box;
  color: var(--color-white);
}
#header .menu_child > .wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#header .menu_child .menu_ttl {
  font-family: var(--font-en);
  font-size: min(3.67vw, 44px);
  font-weight: 600;
}
#header .menu_child .menu_ttl + p {
  margin-top: var(--margin-20);
  font-size: var(--font-size-xs);
  line-height: 1.8;
}
.about_list > ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--margin-30) var(--margin-60);
}
.about_list .index_head {
  margin-bottom: var(--margin-20);
}
.about_list .index_ttl {
  font-size: min(2vw, 24px);
}
.about_list .text_en, .about_list .text_jp {
  line-height: 1.6;
}
.about_list .text_en + .text_jp {
  margin-top: var(--margin-05);
}
#header .menu_contents {
  width: 72.5vw;
}
#header .menu_contents .works_tag > ul > li {
  background-color: #333;
}
#header .menu_contents .btn > a {
  border-bottom-color: var(--color-white);
}
#header .menu_contents .menu_top {
  display: none;
}
.sns > ul {
  display: flex;
  column-gap: min(1.17vw, 14px);
}
.sns svg {
  width: 1.25vw;
  max-width: 15px;
  height: 1.25vw;
  max-height: 15px;
  fill: var(--color-black);
}
#header.active .sns svg {
  fill: var(--color-white);
}

#header + * {
  padding-top: var(--header-height);
}
#main {
  position: relative;
  z-index: 1;
}
#main > section {
  padding: var(--section-padding) 0;
}

#main #visual {
  position: relative;
  height: calc(100dvh - var(--header-height));
  color: var(--color-white);
  padding: 0;
}
.visual_wrap {
  display: flex;
}
.visual_wrap .slide {
  position: relative;
  width: 40%;
  border-radius: 0 min(5vw, 60px) min(5vw, 60px) 0;
  overflow: hidden;
  z-index: 6;
}
.visual_wrap .slide + .slide {
  width: calc(12% - min(-5vw, -60px));
  margin-left: min(-5vw, -60px);
}
.visual_wrap .slide:nth-child(2) {
  z-index: 5;
}
.visual_wrap .slide:nth-child(3) {
  z-index: 4;
}
.visual_wrap .slide:nth-child(4) {
  z-index: 3;
}
.visual_wrap .slide:nth-child(5) {
  z-index: 2;
}
.visual_wrap .slide:last-child {
  border-radius: 0;
  z-index: 1;
}
.visual_wrap .item::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  opacity: .3;
  z-index: 1;
}
.visual_wrap .item img {
  width: 100%;
  height: calc(100dvh - var(--header-height));
  object-fit: cover;
}
.visual_wrap .item .info {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  align-items: flex-end;
  position: absolute;
  bottom: min(3.58vw, 43px);
  right: 0;
  width: 100%;
  padding: 0 min(3.58vw, 43px) 0 calc(min(3.58vw, 43px) + var(--full-contents-padding));
  box-sizing: border-box;
  z-index: 2;
}
.visual_wrap .item .info > p {
  font-family: var(--font-en);
  font-size: 1.67vw;
  font-weight: 500;
  line-height: 1.4;
}
.visual_wrap .item .info .area {
  font-size: 6.67vw;
  font-weight: 600;
  line-height: 1;
  writing-mode: vertical-rl;
}
.scroll {
  position: absolute;
  bottom: min(3.58vw, 43px);
  left: var(--full-contents-padding);
  z-index: 7;
}
.scroll > p {
  display: flex;
  align-items: center;
  column-gap: var(--margin-10);
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  writing-mode: vertical-rl;
}
.scroll > p::after {
  content: "";
  width: 1px;
  height: 12.5vw;
  max-height: 150px;
  background-color: var(--color-white);
}

#main .wrap {
  width: var(--content-width);
  margin-right: calc(var(--full-contents-padding) + 10px);
  margin-left: auto;
}
.section_head + * {
  margin-top: min(7.92vw, 95px);
}
.section_ttl {
  font-family: var(--font-en);
  font-size: min(5.83vw, 70px);
  font-weight: 600;
  line-height: 1.4;
}
.section_ttl_sub {
  font-family: var(--font-en);
  font-size: var(--font-size-xs);
}
.sort {
  margin-bottom: var(--margin-40);
}
.sort .tag_list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--margin-15) var(--margin-15);
}
.sort .tag_list > li > * {
  display: block;
  border: 1px solid var(--color-black);
  border-radius: 9999vw;
  padding: min(0.58vw, 7px) var(--margin-30);
  box-sizing: border-box;
  font-family: var(--font-en);
  font-size: min(1.25vw, 15px);
  transition: background-color var(--hover-transition);
}
.sort .tag_list > li > *.active {
  background-color: #ddd;
}
@media (hover: hover) {
  .sort .tag_list > li > *:hover {
    background-color: #ddd;
  }
}
.news_list > ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5.42vw 1.58vw;
}
.news_item {
  position: relative;
}
.inview {
  transition: clip-path var(--hover-transition);
}
.news_thumb {
  overflow: hidden;
}
.news_thumb::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  opacity: .5;
  transition: opacity var(--hover-transition);
}
.news_thumb img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 5 / 7;
  transition: transform var(--hover-transition);
}
@media (hover: hover) {
  .news_item > a:hover .news_thumb::after {
    opacity: .7;
  }
  .news_item > a:hover .news_thumb img {
    transform: scale(1.05);
  }
}
.news_detail {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  padding: var(--margin-40) var(--margin-30);
  box-sizing: border-box;
  color: var(--color-white);
  font-size: min(1.25vw, 15px);
}
.news_category {
  font-family: var(--font-en);
  font-weight: 700;
}
.news_head {
  margin-top: var(--margin-50);
  line-height: 1.4;
}
.news_ttl {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 8;
  overflow: hidden;
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  font-weight: 700;
  line-height: 1.3;
}
.news_head > p {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 6;
  overflow: hidden;
  margin-top: var(--margin-15);
  font-size: calc(var(--font-size-xs) - 1px);
  text-align: justify;
  word-break: break-all;
}
@media screen and (max-width: 1300px) {
  .news_head {
    margin-top: var(--margin-30);
  }
}
@media screen and (max-width: 1260px) {
  .news_head {
    margin-top: var(--margin-20);
  }
  .news_ttl {
    font-size: calc(var(--font-size-s) - 1px);
  }
}
.news_date {
  display: flex;
  align-items: baseline;
  column-gap: var(--margin-15);
  margin-top: auto;
  font-family: var(--font-en);
}
.news_date > b {
  font-size: min(2.5vw, 30px);
}
.news_date > small {
  font-size: min(1.25vw, 15px);
  font-weight: 700;
}
#now .btn {
  margin-top: min(6.25vw, 75px);
  text-align: right;
}
#concept .btn {
  margin-top: var(--margin-60);
}
.index .btn {
  margin-top: min(3.75vw, 45px);
}
.btn > a {
  display: inline-block;
  padding: 0 min(0.58vw, 7px) min(0.42vw, 5px);
  border-bottom: 1px solid var(--color-black);
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  transition: padding var(--hover-transition);
}
@media (hover: hover) {
  .btn > a:hover {
    padding-right: 0;
    padding-left: 0;
  }
}
.column {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  column-gap: 4.43%;
}
.column_detail {
  flex-shrink: 0;
  width: 55.71%;
}
.detail_head {
  margin-bottom: var(--margin-40);
}
.detail_ttl {
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  font-weight: 500;
}
.detail_head > p {
  font-size: var(--font-size-xs);
}
.detail_ttl + p {
  margin-top: var(--margin-10);
}
.text_en {
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  font-weight: 500;
  line-height: 1.9;
}
.text_jp {
  font-size: var(--font-size-xs);
  line-height: 1.9;
  text-align: justify;
  word-break: break-all;
}
.text_en + .text_jp {
  margin-top: var(--margin-40);
}
#page-about .text_en {
  font-size: var(--font-size-base);
}
#page-about .text_en + .text_jp {
  margin-top: var(--margin-10);
}
#page-about-kenzo .article_txt > p > strong {
  display: block;
  margin-bottom: var(--margin-15);
}
#page-about-kenzo .text_en + .text_en {
  margin-top: var(--margin-15);
}
#page-about-kenzo .text_en + .text_jp {
  margin-top: var(--margin-30);
}
#page-about-kenzo .text_jp + .text_en {
  margin-top: var(--margin-60);
}

.cover {
  width: 100%;
  height: 70vh;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  margin-bottom: var(--section-padding);
  overflow: hidden;
}
#works .cover {
  background-image: url(../img/top/works_cover.webp);
}
#works .section_head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
#works .section_head .btn {
  margin-bottom: var(--margin-25);
}
.works_list > ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--margin-40) min(1.58vw, 19px);
}
#works .works_list > ul {
  grid-template-columns: repeat(3, 1fr);
  column-gap: var(--margin-70);
}
#works .works_list > ul > li:nth-child(3n-2) {
  margin-top: var(--margin-90);
}
#works .works_list > ul > li:nth-child(3n-1) {
  margin-top: calc(var(--margin-90) / 2);
}
.list_img {
  background-color: var(--color-black);
  margin-bottom: var(--margin-20);
  overflow: hidden;
}
.list_img img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 37 / 30;
  transition: transform var(--hover-transition);
}
@media (hover: hover) {
  .list_img a:hover img {
    transform: scale(1.05);
  }
}
.works_list .list_img img {
  object-position: 0 0;
}
.list_detail {
  line-height: 1.4;
}
.list_ttl {
  font-family: var(--font-en);
  font-size: var(--font-size-base);
  font-weight: 700;
}
.list_head > p {
  font-size: var(--font-size-xs);
  margin-top: var(--margin-05);
}
.list_lead .text_en {
  line-height: 1.4;
}
.list_lead .text_jp {
  line-height: 1.4;
}
.works_tag {
  margin-top: var(--margin-15);
}
.works_tag > ul {
  display: flex;
  flex-wrap: wrap;
  gap: var(--margin-10);
  font-size: min(0.71vw, 9px);
}
.works_tag > ul > li {
  background-color: var(--color-gray);
  padding: min(0.33vw, 4px) min(0.42vw, 5px);
}
.list_detail .btn {
  margin-top: var(--margin-25);
}
.list_detail .btn > a {
  font-size: var(--font-size-xs);
}
#no_result {
  font-family: var(--font-en);
}

#about .wrap {
  box-sizing: border-box;
}
.index {
  display: flex;
  justify-content: space-between;
  align-items: center;
  column-gap: 4.43%;
}
.index + .index {
  margin-top: min(9.58vw, 115px);
}
.container > .index:nth-child(even) {
  flex-direction: row-reverse;
}
.index_detail {
  flex-shrink: 0;
  width: 37.38%;
}
.index_head {
  margin-bottom: var(--margin-50);
}
.index_ttl {
  font-family: var(--font-en);
  font-size: min(4vw, 48px);
  font-weight: 500;
}
.index_head > p {
  font-size: var(--font-size-s);
  font-weight: 700;
}
.index_ttl + p {
  margin-top: var(--margin-10);
  font-weight: normal;
}
.index_image img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 1 / 1;
  transition: transform var(--hover-transition);
}
@media (hover: hover) {
  .index_image a:hover img {
    transform: scale(1.025);
  }
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: min(3.75vw, 45px);
}
.grid .item {
  position: relative;
}
.grid .item .background::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--color-black);
  opacity: .3;
}
.grid .item .background img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 161 / 100;
}
.grid .item_head {
  display: grid;
  place-content: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: var(--color-white);
  text-align: center;
}
.grid .item_ttl {
  font-family: var(--font-en);
  font-size: min(2.17vw, 26px);
  font-weight: 500;
}
.grid .item_head > p {
  font-size: var(--font-size-xs);
  margin-top: var(--margin-10);
}

.office_list {
  display: flex;
  column-gap: min(1.42vw, 17px);
}
.office_list > .item {
  display: flex;
  flex-direction: column;
  row-gap: var(--margin-50);
}
.office_detail {
  font-family: var(--font-en);
}
.office_name {
  font-family: var(--font-en);
  font-size: var(--font-size-m);
  font-weight: 600;
}
.office_list .office_name + p {
  margin-top: var(--margin-30);
}
.office_detail > p {
  font-size: var(--font-size-xs);  
  line-height: 1.4;
}
.office_detail > p + p {
  margin-top: var(--margin-10);
}
.office_detail + .office_map {
  margin-top: auto;
}
.office_map iframe {
  filter: grayscale(100%);
  margin-top: auto;
}

.page_head {
  margin-bottom: min(12.92vw, 155px);
  padding: 0 var(--full-contents-padding);
}
.page_ttl {
  font-family: var(--font-en);
  font-size: min(7.42vw, 89px);
  font-weight: 600;
}
.page_ttl > small {
  display: block;
  margin-top: var(--margin-20);
  font-size: calc(var(--font-size-m) + 3px);
}
.page_head .page_ttl + * {
  margin-top: var(--margin-50);
}
.page_head > p:not(.text_jp) {
  font-family: var(--font-en);
  font-weight: 500;
  line-height: 1.9;
}
.page_head > p:not(.text_jp), .page_head .text_en {
  font-size: calc(var(--font-size-xs) + 1px);
}
.page_head > p:not(.text_jp) + .text_jp, .page_head .text_en + .text_jp {
  margin-top: var(--margin-20);
}

.sort .tag_list + * {
  align-items: center;
  margin-top: var(--margin-60);
}
.sort_more {
  display: flex;
  column-gap: var(--margin-25);
}
.sort_select select {
  width: 16.67vw;
  max-width: 200px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%20213.1%20109.1%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23333%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpolygon%20class%3D%22st0%22%20points%3D%22106.6%20109.1%20213.1%200%200%200%20106.6%20109.1%22%2F%3E%3C%2Fsvg%3E') no-repeat center right var(--margin-20) / 0.83vw auto;
  border: 1px solid var(--color-black);
  border-radius: 0;
  box-sizing: border-box;
  padding: min(0.92vw, 11px) var(--margin-20);
  color: var(--color-black);
  font-family: var(--font-en);
  font-size: min(1.25vw, 15px);
  outline: 0;
  -webkit-appearance: none;
  appearance: none;
}
.search_keyword {
  display: flex;
}
.search_keyword > * {
  padding: min(0.92vw, 11px) var(--margin-20);
  box-sizing: border-box;
  font-size: min(1.25vw, 15px);
}
.search_keyword input {
  background-color: var(--color-white);
  border: 1px solid var(--color-black);
  border-radius: var(--main-border-radius) 0 0 var(--main-border-radius);
  outline: 0;
  -webkit-appearance: none;
  appearance: none;
}
.search_keyword button {
  background-color: var(--color-black);
  border: none;
  border-radius: 0 var(--main-border-radius) var(--main-border-radius) 0;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
}
.search_keyword button > p {
  color: var(--color-white);
  font-family: var(--font-en);
}

.single_ttl {
  font-family: var(--font-en);
  font-size: min(4.58vw, 55px);
  font-weight: 600;
  line-height: 1.3;
}
.single_ttl + p {
  margin-top: var(--margin-10);
  line-height: 1.4;
}
.single_subttl {
  font-family: var(--font-en);
  font-size: calc(var(--font-size-xs) + 1px);
  margin-top: var(--margin-70);
}
.works_info {
  margin-top: var(--margin-35);
}
.works_year {
  color: #999;
  font-family: var(--font-en);
  font-size: min(1.25vw, 15px);
  line-height: 1.4;
}
.works_detail {
  margin-top: var(--margin-40);
}
.table {
  display: grid;
  grid-template-columns: minmax(16%, 165px) minmax(84%, calc(100% - 165px));
}
.works_detail .flex {
  display: flex;
  flex-wrap: wrap;
  row-gap: var(--margin-10);
  font-family: var(--font-en);
  font-size: min(1.08vw, 13px);
  line-height: 1.4;
}
.works_detail .flex > dt {
  width: 140px;
}
.works_detail .flex > dd {
  width: calc(100% - 140px);
}
.works_detail .notes {
  margin-top: var(--margin-60);
  font-family: var(--font-en);
  font-size: var(--font-size-xs);
  line-height: 1.6;
}
.works_gallery {
  column-count: 2;
  column-gap: var(--margin-50);
  margin-top: var(--margin-40);
}
.works_gallery.full {
  column-count: 1;
}
.works_gallery > figure {
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  break-inside: avoid;
  padding-top: var(--margin-50);
}
.works_gallery > figure img {
  width: 100%;
}
.back_btn {
  margin-top: var(--margin-80);
}
.material-icons {
  font-family: Material Icons;
}
.back_btn .material-icons {
  font-size: min(2vw, 24px);
  transition: color var(--hover-transition);
}
@media (hover: hover) {
  .back_btn > a:hover .material-icons {
    color: #ccc;
  }
}

.pagination {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  column-gap: var(--margin-15);
  margin-top: var(--margin-50);
  font-family: var(--font-en);
}
.pagination > ul > li .material-icons {
  font-size: min(3.33vw, 40px);
}
.pagination > *:not(.prev):not(.next):not(.dots) {
  display: grid;
  place-content: center;
  width: 3.58vw;
  max-width: 43px;
  height: 3.58vw;
  max-height: 43px;
  border: 1px solid var(--color-black);
  border-radius: 50%;
  font-size: min(1.08vw, 13px);
  transition: background-color var(--hover-transition);
}
.pagination > .current {
  background-color: #ddd;
}
@media (hover: hover) {
  .pagination > a:hover:not(.prev):not(.next) {
    background-color: #ddd;
  }
}
.pagination > .prev, .pagination > .next {
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: min(3.33vw, 40px);
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  display: inline-block;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.project_list > ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: min(9.58vw, 115px) var(--margin-20);
  padding-bottom: min(16.67vw, 200px);
}
.project_list > ul > li {
  position: relative;
}
.project_list > ul > li:nth-child(even) {
  top: min(16.67vw, 200px);
}
.project_list .list_img img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 3 / 2;
}
.list_lead {
  margin-top: var(--margin-20);
}
.list_lead .text_en + .text_jp {
  margin-top: var(--margin-10);
  font-size: calc(var(--font-size-xs) - 1px);
}

#main > section:has(.page_visual) {
  padding-top: 0;
}
.page_visual {
  position: relative;
  margin-bottom: var(--margin-70);
}
.page_visual img {
  width: 100%;
  height: 40vw;
  max-height: 480px;
  object-fit: cover;
}
.page_visual_wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: min(6.25vw, 75px) var(--full-contents-padding);
  box-sizing: border-box;
}

.article_head {
  margin-bottom: var(--margin-90);
}
.article_ttl {
  font-family: var(--font-en);
  font-size: min(4.58vw, 55px);
  font-weight: 700;
}
.article_ttl + p {
  margin-top: var(--margin-10);
}
.notes {
  color: #999;
  margin-top: var(--margin-30);
}
.notes .text_en + .text_jp {
  margin-top: 0;
}
.intro_head {
  margin-bottom: var(--margin-40);
}
.intro_ttl_shoulder {
  display: block;
  font-family: var(--font-en);
  font-size: min(1.5vw, 20px);
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: min(1.5vw, 12px);
}
.intro_ttl {
  font-family: var(--font-en);
  font-size: min(2.5vw, 30px);
  font-weight: 700;
  line-height: 1.2;
}
.intro_ttl > span {
  display: block;
  color: #999;
  font-size: min(1.58vw, 19px);
  margin-bottom: var(--margin-10);
}
.intro_head > p {
  margin-top: var(--margin-10);
  font-size: calc(var(--font-size-xs) + 1px);
  line-height: 1.6;
}
.article_body > * + * {
  margin-top: var(--margin-90);
}
.article_column .article_wrap {
  display: flex;
  justify-content: space-between;
  width: var(--content-width-noR);
}
.article_column .article_wrap > * {
  width: 47.58%;
}
.article_column.reverse .article_wrap,
#page-about-dna .article_column:nth-child(even) .article_wrap {
  flex-direction: row-reverse;
  width: 100%;
}
.article_column .article_wrap .article_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.article_column .article_wrap .article_img figcaption {
  margin-top: var(--margin-30);
  font-size: calc(var(--font-size-xs) + 1px);
}
.article_column .article_wrap .article_img figcaption > span {
  display: block;
  margin-bottom: var(--margin-10);
}
.article_column .article_wrap .article_img figcaption > b {
  display: block;
  font-family: var(--font-en);
  font-size: min(1.88vw, 22px);
  font-weight: 700;
  margin-bottom: var(--margin-10);
}
.article_full .article_wrap {
  display: flex;
  flex-direction: column;
  row-gap: var(--margin-60);
}
.article_full .article_wrap .article_img img {
  width: 100%;
}
.article_link {
  text-align: right;
}
.article_link > a {
  display: inline-block;
  background-color: var(--color-black);
  border-radius: var(--main-border-radius);
  padding: var(--margin-20) var(--margin-70);
  box-sizing: border-box;
  color: var(--color-white);
  font-family: var(--font-en);
  text-align: center;
  transition: background-color var(--hover-transition);
}
@media (hover: hover) {
  .article_link > a:hover {
    background-color: #444;
  }
}
.article_link > a > span::after {
  content: "";
  display: inline-block;
  width: 0.83vw;
  max-width: 10px;
  height: 0.83vw;
  max-height: 10px;
  margin-left: var(--margin-10);
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2015%2015%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M5%2C0v2h6.6L0%2C13.6l1.4%2C1.4L13%2C3.4v6.6h2V0H5Z%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 100% auto;
}
.article_summary {
  margin-top: var(--margin-40);
}
.article_summary .text_en {
  font-size: var(--font-size-base);
  font-weight: 700;
}
.article_summary .text_en b {
  font-weight: bold;
}
.article_summary .text_en + .text_jp {
  margin-top: var(--margin-10);
}
.article_summary .text_jp {
  font-size: calc(var(--font-size-xs) + 1px);
}
.article_more {
  margin-top: var(--margin-100);
}
.more_head {
  margin-bottom: var(--margin-40);
}
.more_ttl {
  font-family: var(--font-en);
  font-size: min(3.33vw, 40px);
  font-weight: 700;
}
.article_more > ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--margin-40) min(1.5vw, 18px);
}

#page-about .container {
  width: var(--content-width-noR);
}

#archive-people > .container {
  padding: 0 var(--full-contents-padding);
}
#archive-people > .container > .block + .block {
  margin-top: var(--margin-100);
}
.block_head {
  margin-bottom: var(--margin-40);
}
.block_ttl {
  font-family: var(--font-en);
  font-size: min(4.17vw, 50px);
  font-weight: 500;
}
.people_list > ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--margin-40) min(1.5vw, 18px);
}
.people_list > ul + ul {
  margin-top: var(--margin-40);
}
.people_item {
  position: relative;
  background-color: var(--color-black);
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  #archive-people > .container > .block:first-of-type .people_list > ul > .people_item:first-child {
    grid-area: 1 / 1 / 2 / 2;
  }
  #archive-people > .container > .block:first-of-type .people_list > ul > .people_item:nth-child(2) {
    grid-area: 2 / 2 / 3 / 3;
  }
  #archive-people > .container > .block:first-of-type .people_list > ul > .people_item:nth-child(3) {
    grid-area: 2 / 1 / 3 / 2;
  }
}
.people_thumb img {
  width: 100%;
  object-fit: cover;
  aspect-ratio: 281 / 132;
  transition: transform var(--hover-transition), opacity var(--hover-transition);
}
@media (hover: hover) {
  .people_item > a:hover .people_thumb img {
    transform: scale(1.05);
    opacity: .6;
  }
}
.people_detail {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  padding: 0 var(--margin-30);
  box-sizing: border-box;
  color: var(--color-white);
  font-family: var(--font-en);
  font-weight: 500;
}
.people_position {
  margin-bottom: var(--margin-10);
}
.people_position > p {
  font-size: 1vw;
  line-height: 1.4;
}
.people_position > p + p {
  margin-top: var(--margin-05);
}
.people_name {
  font-size: 2.25vw;
}
.people_name + p {
  margin-top: var(--margin-30);
}
.people_detail > p {
  font-size: 0.92vw;
}
.staff_list > ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  column-gap: min(1.5vw, 18px);
}
.staff_list > ul > li {
  border-top: 1px solid var(--color-black);
  padding: var(--margin-25) 0;
  font-family: var(--font-en);
}
.staff_position {
  font-size: var(--font-size-s);
  margin-bottom: var(--margin-10);
}
.staff_name {
  font-size: min(1.67vw, 20px);
  font-weight: 500;
}
.staff_area {
  font-size: min(0.92vw, 11px);
  font-weight: 400;
  margin-top: var(--margin-10);
}
#single-people .page_visual {
  margin-bottom: var(--margin-90);
  color: var(--color-white);
}
#single-people .page_visual img {
  height: 54.17vw;
  max-height: 650px;
}
#single-people .page_visual_wrap {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.page_lead .text_en {
  font-size: min(2.6vw, 36px);
  line-height: 1.3;
}
.page_lead .text_en + .text_jp {
  margin-top: var(--margin-10);
}
.page_lead .text_jp {
  font-size: min(1.08vw, 13px);
}
#single-people .people_detail {
  position: static;
  transform: none;
  padding: 0;
}
@media screen and (min-width: 1200px) {
  #single-people .people_position > p {
    font-size: 12px;
    line-height: 1.6;
  }
  #single-people .people_position.thumb > p {
    font-size: 11px;
  }
  #single-people .people_name {
    font-size: 32px;
  }
  #single-people .people_name.thumb {
    font-size: 22px;
  }
  #single-people .people_detail > p {
    font-size: 12px;
  }
}
#single-people > .container {
  width: 84.17vw;
  margin: auto;
}
.column_body {
  width: 58.91%;
}
.article_block + .article_block {
  margin-top: var(--margin-70);
}
.column_body .article_head {
  margin-bottom: var(--margin-30);
}
.column_body .article_ttl {
  font-size: min(2vw, 26px);
  font-weight: 500;
  line-height: 1.3;
}
.column_body .article_ttl_jp {
  font-size: calc(var(--font-size-xs) - 1px);
}
.column_side {
  width: 41.09%;
}
.column_side > * + * {
  margin-top: var(--margin-50);
}
.side_head {
  border-top: 1px solid var(--color-black);
  padding-top: var(--margin-30);
  margin-bottom: var(--margin-20);
}
.side_ttl {
  font-family: var(--font-en);
  font-size: min(1.88vw, 22px);
  font-weight: 700;
}
#single-people .list_img img {
  object-position: right center;
  aspect-ratio: 497 / 484;
  transition: transform var(--hover-transition), opacity var(--hover-transition);
}
@media (hover: hover) {
  #single-people .article_more > ul > li > a:hover .list_img img {
    transform: scale(1.05);
    opacity: .6;
  }
}
.article_more .people_detail {
  color: var(--color-black);
}
.article_more .people_name + p {
  margin-top: var(--margin-15);
}

#page-about-office .container {
  width: var(--content-width-noR);
}
#page-about-office .column {
  align-items: stretch;
}
#page-about-office .column + .column {
  margin-top: min(12.5vw, 150px);
}
#page-about-office .column_detail {
  display: flex;
  flex-direction: column;
  flex-shrink: 1;
  width: auto;
}
.office_head .office_name {
  font-size: min(2.5vw, 30px);
}
.office_head .office_name_jp {
  font-size: calc(var(--font-size-xs) + 1px);
  margin-top: var(--margin-05);
}
.column .office_detail {
  margin-top: auto;
}
.column .office_detail > p {
  font-size: calc(var(--font-size-xs) + 1px);
  line-height: 1.8;
}
.column .office_map {
  flex-shrink: 0;
}
.column .office_map iframe {
  width: 65.74vw;
  height: 100%;
  aspect-ratio: 71 / 30;
}

#page-about-visoin .article_column .article_wrap {
  flex-direction: row-reverse;
  width: 100%;
}
#page-about-visoin .article_column .article_wrap > .article_txt {
  width: 52.5%;
}
#page-about-visoin .intro_ttl {
  font-size: min(3.33vw, 40px);
}
.article_item + .article_item {
  margin-top: var(--margin-60);
}
.article_item_ttl {
  font-family: var(--font-en);
  font-size: min(3.33vw, 40px);
  font-weight: 700;
}
.article_item_ttl::after {
  content: "";
  display: block;
  width: 2.75vw;
  max-width: 33px;
  height: 1px;
  background-color: var(--color-black);
  margin-top: var(--margin-25);
}
.article_item_body .article_summary {
  margin-bottom: var(--margin-10);
}
.article_item_body .article_summary:has(.text_jp) {
  margin-bottom: var(--margin-30);
}
.article_item_body > .article_item_txt + .article_item_txt {
  margin-top: var(--margin-30);
}
.article_item_body .article_summary .text_en + .text_jp {
  margin-top: var(--margin-05);
}
.article_item_body .article_summary .text_en {
  font-size: calc(var(--font-size-base) - 1px);
  font-weight: 500;
  line-height: 1.6;
}
.article_item_txt .text_en {
  line-height: 1.6;
}
.article_item_txt .text_en + .text_jp {
  margin-top: var(--margin-10);
}
.article_vision {
  width: 42.16%;
}
.article_column .article_wrap .article_vision {
  position: relative;
  width: 35.42%;
  background: url(../img/about/vision_bg_pc.png) no-repeat center center / auto 100%;
}
.article_vision .vision_block {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 15.33vw;
  max-width: 184px;
  height: 31.46vw;
  max-height: 377px;
  border-radius: 9999vw;
  text-align: center;
  overflow: hidden;
}
.article_vision .vision_block::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(0deg, #dbdcf1, #5050e4);
  opacity: .7;
  z-index: 1;
}
.article_vision .vision_block:nth-child(odd) {
  right: min(-11.08vw, -133px);
}
.article_vision .vision_block:nth-child(even) {
  left: min(-11.08vw, -133px);
}
.article_vision .vision_block:nth-child(2) {
  margin-top: var(--margin-60);
}
.article_vision .vision_block:nth-child(3) {
  margin-top: calc(var(--margin-60) * 2);
}
.article_vision .vision_block > a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  padding: var(--margin-35) 0;
  box-sizing: border-box;
  color: var(--color-white);
  pointer-events: none;
  z-index: 2;
}
.article_vision .vision_block .article_item_ttl {
  font-size: min(2.17vw, 26px);
  font-weight: 500;
  margin-bottom: var(--margin-10);
}
.article_vision .vision_block .article_item_ttl::after {
  display: none;
}
.article_vision .vision_block .text_jp {
  text-align: center;
}
.article_vision .vision_block .text_jp > br {
  display: none;
}

.history_list {
  margin-top: var(--margin-80);
}
.history_head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: min(9.17vw, 110px);
  font-family: var(--font-en);
}
.history_head_ttl {
  font-size: min(5.33vw, 64px);
  font-weight: 600;
}
.history_scroll {
  display: flex;
  align-items: center;
  column-gap: var(--margin-70);
  font-size: min(1.67vw, 20px);
}
.history_body {
  display: flex;
  width: var(--content-width-noR);
  overflow-x: scroll;
}
.history_wrap {
  display: grid;
  grid-template-columns: auto auto;
  align-items: center;
}
.history_era {
  position: relative;
  font-family: var(--font-en);
  font-size: min(4vw, 48px);
  font-weight: 600;
  white-space: nowrap;
  z-index: 2;
}
.history_era > span {
  background-color: var(--color-white);
  padding: 0 var(--margin-20);
}
.history_block::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: min(0.25vw, 6px);
  margin: auto;
  background-color: var(--color-blue);
  z-index: 1;
}
.history_block {
  position: relative;
  display: grid;
  grid-auto-flow: column;
  grid-template-rows: repeat(2, auto);
  height: calc(275px * 2);
}
.history_item {
  display: flex;
  width: 274px;
  height: 275px;
  border-left: 1px solid var(--color-black);
  padding: var(--margin-20) var(--margin-20) var(--margin-40);
  box-sizing: border-box;
}
.history_item:nth-child(odd) {
  margin-left: -40px;
}
.history_item:first-child {
  margin-left: 40px;
}
.history_item:nth-child(2) {
  margin-left: 80px;
}
.history_item > * {
  display: flex;
  flex-direction: column;
}
.history_year {
  font-family: var(--font-en);
  font-size: calc(var(--font-size-base) - 1px);
  font-weight: 500;
  margin-bottom: var(--margin-20);
}
.history_detail > p {
  line-height: 1.1;
}
.history_detail .text_en {
  font-size: var(--font-size-xs);
}
.history_detail .text_jp {
  font-size: calc(var(--font-size-xs) - 1px);
}
.history_detail .text_en + .text_jp {
  margin-top: var(--margin-05);
}
.history_img {
  margin-top: auto;
  overflow: hidden;
}
.history_img img {
  height: 9.83vw;
  max-height: 118px;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  transition: transform var(--hover-transition);
}
@media (hover: hover) {
  .history_item > a:hover .history_img img {
    transform: scale(1.05);
  }
}

.awards_list {
  font-family: var(--font-en);
}
.awards_list > ul > li {
  display: grid;
  grid-template-columns: 43% 35% 8% 5%;
  column-gap: 3%;
}
.awards_list_head {
  margin-bottom: var(--margin-50);
  color: #999;
  font-size: calc(var(--font-size-base) - 2px);
}
.awards_list_body > li {
  border-bottom: 1px solid #ccc;
  padding-bottom: var(--margin-30);
  margin-bottom: var(--margin-30);
  line-height: 1.4;
}
.awards_list_body > li > p > a {
  transition: opacity var(--hover-transition);
}
.awards_list_body > li > p > a::after {
  content: "";
  display: inline-block;
  width: 0.83vw;
  max-width: 10px;
  height: 0.83vw;
  max-height: 10px;
  margin-left: var(--margin-10);
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2015%2015%22%3E%20%3Cpath%20d%3D%22M5%2C0v2h6.6L0%2C13.6l1.4%2C1.4L13%2C3.4v6.6h2V0H5Z%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 100% auto;
}
@media (hover: hover) {
  .awards_list_body > li > p > a:hover {
    opacity: .2;
  }
}
.awards_list .icon {
  display: flex;
  column-gap: var(--margin-10);
}
.awards_list .icon img {
  width: auto;
  height: 1.33vw;
  max-height: 16px;
}

.page_intro {
  border-bottom: 1px solid var(--color-black);
  padding-bottom: var(--margin-70);
  margin-bottom: var(--margin-60);
}
.page_intro .intro_ttl {
  font-size: min(3.33vw, 40px);
}
.page_intro .text_en + .text_jp {
  margin-top: var(--margin-10);
}
.page_table .table {
  grid-template-columns: minmax(40.21%, 423px) minmax(59.79%, calc(100% - 423px));
  row-gap: var(--margin-40);
}
.page_table .table .text_en {
  font-size: calc(var(--font-size-base) - 1px);
}
.page_table .table .text_en + .text_jp {
  margin-top: var(--margin-05);
}
.page_form .page_table .table > dt:first-of-type, .page_form .page_table .table > dd:first-of-type {
  border-bottom: 1px solid #999;
  padding-bottom: var(--margin-40);
}
.page_table .table dd p {
  font-size: var(--font-size-xs);
  line-height: 1.6;
}
.page_foot {
  width: 59.79%;
  max-width: calc(100% - 423px);
  margin-top: var(--margin-100);
  margin-left: auto;
}
.page_foot .text_en + .text_jp {
  margin-top: var(--margin-05);
}
.page_foot .btn_submit {
  margin-top: var(--margin-30);
}
.page_foot .btn_submit > a, .page_foot .btn_submit input[type="submit"],
.page_foot .btn_submit > a, .page_foot .btn_submit input[type="button"] {
  display: block;
  width: 100%;
  background-color: var(--color-black);
  border: none;
  border-radius: var(--main-border-radius);
  padding: var(--margin-25);
  box-sizing: border-box;
  color: var(--color-white);
  font-family: var(--font-en);
  font-size: min(1.67vw, 20px);
  font-weight: 500;
  text-align: center;
  cursor: pointer;
  transition: background-color var(--hover-transition);
}
.page_foot .btn_submit input[type="submit"]:disabled {
  background-color: #ccc;
  cursor: not-allowed;
}
.page_foot .btn_submit input[type="button"] {
  background-color: #888;
}
@media (hover: hover) {
  .page_foot .btn_submit > a:hover, .page_foot .btn_submit input[type="submit"]:not(:disabled):hover {
    background-color: #444;
  }
}
.page_foot .btn_submit.confirm > * {
  display: flex;
  column-gap: var(--margin-10);
}
#page-contact .page_intro {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: var(--margin-90);
}
#page-contact .wpcf7-spinner {
  display: none !important;
}

.page_intro_block + .page_intro_block {
  margin-top: var(--margin-100);
}
.page_intro .column {
  justify-content: flex-start;
  column-gap: 0;
}
.page_intro .column + .column {
  margin-top: var(--margin-40);
}
.page_intro .column .text_en {
  font-size: calc(var(--font-size-base) - 1px);
}
.page_intro .column_head {
  width: 38.5%;
  max-width: 405px;
}
.page_intro .column_head .text_jp {
  line-height: 1;
}
.page_intro .column_body {
  width: auto;
}
.page_intro .column_body .text_en > strong {
  font-size: min(3.33vw, 40px);
  font-weight: 700;
  line-height: 1;
}
.red {
  color: #f23a3c;
}
.page_form .form_label {
  display: flex;
}
.page_form .form_label + .form_label {
  margin-top: var(--margin-20);
}
.page_form .form_label input {
  margin: 0 var(--margin-10) 0 0;
}
.page_form .form_wrap input[type="radio"] {
  width: 1.67vw;
  max-width: 20px;
  height: 1.67vw;
  max-height: 20px;
  margin: 0 var(--margin-05) 0 0;
}
.page_form .form_wrap .wpcf7-radio {
  display: flex;
  flex-direction: column;
  row-gap: var(--margin-20);
}
.page_form .form_wrap .wpcf7-radio .wpcf7-list-item label {
  display: flex;
}
.page_form .form_wrap .wpcf7-radio .wpcf7-list-item-label {
  font-family: var(--font-en);
  font-size: calc(var(--font-size-base) - 1px);
  font-weight: 500;
  line-height: 1.4;
}
.page_form .form_wrap .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label::after {
  display: block;
  margin-top: var(--margin-05);
  font-size: var(--font-size-xs);
  font-weight: 400;
  line-height: 1;
}
.page_form .form_wrap .radio_type-of-inquiry .wpcf7-list-item.first .wpcf7-list-item-label::after {
  content: "建築・設計・デザインのご相談・ご依頼";
}
.page_form .form_wrap .radio_type-of-inquiry .wpcf7-list-item:nth-child(2) .wpcf7-list-item-label::after {
  content: "マスメディア・広告・講演会出演等のご相談・ご依頼\A Contact: Global Promotion inc.";
  white-space: pre-line;
  line-height: 1.4;
}
.page_form .form_wrap .radio_type-of-inquiry .wpcf7-list-item.last .wpcf7-list-item-label::after {
  content: "採用について";
}
.page_form .form_wrap .radio_private-corporate .wpcf7-list-item.first .wpcf7-list-item-label::after {
  content: "法人";
}
.page_form .form_wrap .radio_private-corporate .wpcf7-list-item.last .wpcf7-list-item-label::after {
  content: "個人";
}
.page_form .form_label .text_en {
  line-height: 1.4;
}
.page_form .form_label .text_jp {
  line-height: 1;
}
.page_form input[type="text"],
.page_form input[type="email"],
.page_form input[type="tel"],
.page_form textarea {
  width: 100%;
  background-color: var(--color-white);
  border: 1px solid #999;
  border-radius: var(--main-border-radius);
  padding: var(--margin-10);
  box-sizing: border-box;
  color: var(--color-black);
  font-size: var(--font-size-base);
  line-height: 1.67;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.page_form textarea {
  height: 200px;
}
.page_form input[type="text"]:focus,
.page_form input[type="email"]:focus,
.page_form input[type="tel"]:focus,
.page_form textarea:focus {
  border-color: var(--color-black);
}
.page_form .form_notes {
  margin-top: var(--margin-15);
}
.page_form .form_notes .text_en {
  font-size: calc(var(--font-size-xs) + 1px);
  line-height: 1.6;
}
.page_form .form_notes .text_jp {
  font-size: calc(var(--font-size-xs) - 1px);
  line-height: 1.9;
}
.page_box {
  max-height: 300px;
  margin-top: var(--margin-80);
  padding: var(--margin-35);
  background-color: #e9e9e9;
  border-radius: var(--main-border-radius);
  box-sizing: border-box;
  overflow: scroll;
}
.page_box > * + * {
  margin-top: var(--margin-30);
}
.page_box .box_ttl {
  font-family: var(--font-en);
  font-size: calc(var(--font-size-base) - 1px);
  font-weight: 500;
}
.page_box .box_head > p {
  font-size: calc(var(--font-size-xs) + 1px);
  margin-top: var(--margin-10);
}
.page_box .text_en + .text_jp {
  margin-top: var(--margin-05);
}
.page_box .text_jp {
  line-height: 1.4;
}
.page_box .table {
  grid-template-columns: minmax(26.9%, 283px) minmax(73.1%, calc(100% - 283px));
  row-gap: var(--margin-20);
}
.page_box + .page_foot {
  margin-top: var(--margin-50);
}
.page_foot .form_label {
  margin-bottom: var(--margin-30);
}
.page_form .wpcf7-list-item {
  margin: 0;
}
.page_foot .form_label label {
  display: flex;
  align-items: center;
  font-family: var(--font-en);
  font-size: calc(var(--font-size-base) - 1px);
  font-weight: 500;
  line-height: 1.4;
}
.page_foot .btn_submit input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
#page-contact .article_body .text_en + .text_jp {
  margin-top: var(--margin-10);
}
.page_form .wpcf7-not-valid-tip {
  margin-top: var(--margin-10);
  color: #f23a3c;
  font-size: var(--font-size-xs);
}
#page-contact .wpcf7 form .wpcf7-response-output {
  margin: var(--margin-10) 0 0;
  padding: 0;
  border: none;
  color: #f23a3c;
  font-size: var(--font-size-xs);
  text-align: right;
}
#page-contact .wpcf7 form.invalid .wpcf7-response-output, #page-contact .wpcf7 form.unaccepted .wpcf7-response-output, #page-contact .wpcf7 form.payment-required .wpcf7-response-output {
  border: none;
}

.article_date {
  font-family: var(--font-en);
  font-size: var(--font-size-s);
  margin-bottom: var(--margin-20);
}
#single-news .article_ttl + .article_ttl_jp {
  margin-top: var(--margin-15);
}
#single-news .article_body > div > * + * {
  margin-top: var(--margin-20);
}
#single-news .article_body strong {
  font-weight: 700;
}
#single-news .article_body em {
  font-style: italic;
}
#single-news .article_body a {
  text-decoration: underline;
}
@media (hover: hover) {
  #single-news .article_body a:hover {
    text-decoration: none;
  }
}

#footer {
  position: relative;
  background-color: var(--color-black);
  padding: min(6.17vw, 74px) var(--full-contents-padding) min(2.33vw, 28px);
  color: var(--color-white);
  z-index: 1;
}
#footer > .wrap {
  display: flex;
  justify-content: space-between;
}
.footer_main .logo svg {
  width: 14.58vw;
  max-width: 175px;
  height: 3.25vw;
  max-height: 39px;
  fill: var(--color-white);
}
.footer_main .sns {
  margin-top: var(--margin-20);
}
.footer_main .sns svg {
  width: 1.67vw;
  max-width: 20px;
  height: 1.67vw;
  max-height: 20px;
  fill: var(--color-white);
}
.footer_contents {
  display: flex;
  column-gap: min(16.5vw, 198px);
}
.footer_menu {
  font-family: var(--font-en);
  font-size: min(1.67vw, 20px);
  font-weight: 600;
}
.footer_menu a {
  color: var(--color-white);
}
.footer_menu li + li {
  margin-top: var(--margin-20);
}
.footer_title {
  margin-bottom: var(--margin-20);
  font-family: var(--font-en);
  font-size: var(--font-size-m);
  font-weight: 600;
}
.footer_info > p {
  font-size: var(--font-size-s);
  line-height: 1.6;
}
.copyright {
  margin-top: var(--margin-35);
  font-family: var(--font-en);
  font-size: min(0.92vw, 11px);
}

#loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateY(0%);
  background-color: var(--color-white);
  pointer-events: none;
  z-index: 9999;
  animation: loadingUp 1.2s var(--main-easing) forwards;
}
@keyframes loadingUp {
    100% {
        transform: translateY(-100%);
    }
}


@media screen and (min-width: 769px) {
  #header .menu_btn {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  :root {
    --font-size-base: 3.5vw;
    --font-size-m: 4vw;
    --font-size-s: 3vw;
    --font-size-xs: 2.5vw;
    --content-width-noR: calc(100% + ((100vw - var(--content-width)) / 2));
    --header-height-responsive: 15vw;
    --margin-05: 1.5vw;
    --margin-10: 2vw;
    --margin-15: 2.5vw;
    --margin-20: 3vw;
    --margin-25: 3.5vw;
    --margin-30: 4vw;
    --margin-35: 4.5vw;
    --margin-40: 5vw;
    --margin-50: 6vw;
    --margin-60: 7vw;
    --margin-70: 8vw;
    --margin-80: 9vw;
    --margin-90: 10vw;
    --margin-100: 11vw;
    --full-contents-padding: calc(((100vw - var(--content-width)) / 2));
    --section-padding: 12vw;
    --main-border-radius: 1vw;
  }

  #header .logo svg {
    width: 19.25vw;
    height: 4.25vw;
  }
  #header .gnavi {
    flex-direction: row-reverse;
    column-gap: var(--margin-30);
  }
  #header .menu_btn {
    font-family: var(--font-en);
    font-size: var(--font-size-s);
  }
  #header.active .menu_btn {
    color: var(--color-white);
  }
  #header .menu > ul {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    max-height: calc(100dvh - var(--header-height-responsive));
    background-color: var(--color-black);
    padding: var(--margin-20) 0 var(--margin-100);
    box-sizing: border-box;
    overflow: scroll;
  }
  #header .menu > ul > li {
    font-size: var(--font-size-m);
  }
  #header .menu > ul > li + li {
    margin-top: var(--margin-50);
  }
  #header .menu > ul > li > a {
    display: block;
    padding: 0 var(--full-contents-padding);
    color: var(--color-white);
  }
  #header .menu > ul > li:not(.search) > a::after {
    display: none;
  }
  #header .menu > ul > li > a::before, #header .menu_contents .menu_top > a::before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    right: var(--full-contents-padding);
    margin: auto;
    width: 3.5vw;
    height: 3.5vw;
    background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2024%2024%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M7.7%2C0l-2.8%2C2.8%2C9.2%2C9.2-9.2%2C9.2%2C2.8%2C2.8%2C12-12L7.7%2C0Z%22%2F%3E%3C%2Fsvg%3E') no-repeat center center / 100% auto;
  }
  #header .menu_contents .menu_top > a::before {
    right: 0;
  }
  #header .menu > ul > li:has(.menu_child) > a::before {
    background-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2014%2014%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M14%2C8h-6v6h-2v-6H0v-2h6V0h2v6h6v2Z%22%2F%3E%3C%2Fsvg%3E');
  }
  #header .menu > ul > li:has(.menu_child) > a.active::before {
    transform: rotate(45deg);
  }
  #header .menu_child {
    position: static;
    padding-top: var(--margin-70);
    padding-bottom: var(--margin-70);
  }
  #header .menu_child > .wrap {
    flex-direction: column;
    align-items: flex-start;
    row-gap: var(--margin-60);
  }
  #header .menu_child > .wrap > hgroup {
    display: none;
  }
  #header .menu_contents {
    width: 100%;
  }
  #header .menu_contents .menu_top {
    display: block;
    margin-bottom: var(--margin-60);
  }
  #header .menu_contents .menu_top > a {
    position: relative;
    display: block;
  }
  .about_list > ul {
    grid-template-columns: repeat(2, 1fr);
  }
  .about_list .index_ttl {
    font-size: 4vw;
  }
  #header .menu > ul > li.search {
    display: none;
  }
  .sns > ul {
    column-gap: var(--margin-10);
  }
  .sns svg {
    width: 4vw;
    height: 4vw;
  }

  .visual_wrap .slide {
    width: 60%;
  }
  .visual_wrap .slide + .slide {
    width: calc(20% - min(-5vw, -60px));
  }
  .visual_wrap .slide:nth-child(3) {
    border-radius: 0;
  }
  .visual_wrap .slide:nth-child(n+4) {
    display: none;
  }
  .visual_wrap .item .info {
    padding-left: 9vw;
  }
  .visual_wrap .item .info > p {
    font-size: 3.6vw;
  }
  .visual_wrap .item .info .area {
    font-size: 10vw;
  }
  .scroll {
    left: 3vw;
  }
  .scroll > p {
    font-size: 3vw;
  }
  .scroll > p::after {
    height: 20vw;
  }

  #main .wrap {
    margin-right: auto;
  }
  .section_ttl {
    font-size: 8vw;
  }
  .sort .tag_list {
    flex-wrap: nowrap;
    column-gap: var(--margin-10);
    overflow-x: scroll;
  }
  .sort .tag_list > li {
    flex-shrink: 0;
  }
  .sort .tag_list > li > * {
    font-size: 3vw;
    line-height: 1.4;
  }

  .news_list > ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 3vw;
  }
  .news_detail {
    padding: 6vw 5vw;
    font-size: 3.2vw
  }
  .news_ttl {
    -webkit-line-clamp: 6;
    font-size: 2.8vw;
  }
  .news_head > p {
    -webkit-line-clamp: 5;
    font-size: 2vw;
  }
  .news_date > b {
    font-size: 6vw;
  }
  .news_date > small {
    font-size: 3vw;
  }

  .column {
    flex-direction: column;
    row-gap: var(--margin-100);
  }
  .column_detail {
    width: 100%;
  }
  .detail_ttl {
    font-size: 3.2vw;
  }

  .cover {
    height: 60vw;
  }
  #works .section_head .btn {
    margin-bottom: var(--margin-20);
  }
  #works .works_list > ul {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--margin-20) var(--margin-30);
  }
  #works .works_list > ul > li:nth-child(3n-2),
  #works .works_list > ul > li:nth-child(3n-1) {
    margin-top: 0;
  }
  #works .works_list > ul > li:nth-child(odd) {
    margin-top: var(--margin-80);
  }
  .list_ttl {
    font-size: 3.5vw;
  }
  .works_tag {
    margin-top: var(--margin-25);
  }
  .works_tag > ul {
    font-size: 2vw;
  }
  .works_tag > ul > li {
    padding: 1vw 2vw;
  }
  .list_detail .btn > a {
    font-size: var(--font-size-xs);
  }

  .index {
    flex-direction: column-reverse;
    row-gap: var(--margin-60);
  }
  .index + .index {
    margin-top: 15vw;
  }
  .container > .index:nth-child(even) {
    flex-direction: column-reverse;
  }
  .index_detail {
    width: 100%;
  }
  .index_ttl {
    font-size: 7vw;
  }
  .index_ttl > br {
    display: none;
  }
  .index_head > p {
    font-size: 3vw;
    line-height: 1.2;
  }
  .index .btn {
    margin-top: var(--margin-60);
  }

  .slider_gallery img {
    height: 60vw;
  }

  .grid .item_ttl {
    font-size: 4vw;
  }

  .office_list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12vw min(3.75vw, 45px);
  }
  .office_map iframe {
    height: 70vw;
  }

  .page_visual img {
    object-position: center center;
  }
  .page_ttl {
    font-size: 8vw;
  }
  .page_ttl > small {
    font-size: 4vw;
  }
  .sort:has(.column) {
    margin-bottom: var(--margin-100);
  }
  .sort .tag_list + * {
    row-gap: var(--margin-40);
  }
  .sort_more {
    width: 100%;
  }
  .sort_select {
    width: calc((100% - var(--margin-25)) / 2);
  }
  .sort_select select {
    width: 100%;
    background-size: 2.2vw auto;
    font-size: var(--font-size-xs);
    line-height: 2;
  }
  .search_keyword {
    width: 100%;
  }
  .search_keyword > * {
    font-size: var(--font-size-xs);
    line-height: 2;
  }
  .search_keyword input {
    width: 80%;
    font-size: 16px;
  }
  .search_keyword input::placeholder {
    font-size: var(--font-size-s);
  }
  .search_keyword button {
    width: 20%;
  }
  .works_list > ul {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--margin-80) var(--margin-30);
  }
  .single_ttl {
    font-size: 5vw;
  }
  .single_ttl + p {
    font-size: 3.2vw;
  }
  .works_year {
    font-size: 3.2vw;
  }
  .works_detail {
    margin-top: var(--margin-60);
  }
  .works_detail .flex {
    font-size: var(--font-size-xs);
  }
  .works_gallery {
    column-gap: var(--margin-30);
  }
  .works_gallery > figure {
    padding-top: var(--margin-30);
  }
  .back_btn .material-icons {
    font-size: 5vw;
  }

  .pagination {
    margin-top: var(--margin-80);
    font-size: var(--font-size-xs);
  }
  .pagination > *:not(.prev):not(.next):not(.dots) {
    width: 7vw;
    height: 7vw;
    font-size: 2.8vw;
  }
  .pagination > .prev, .pagination > .next {
    font-size: 7vw;
  }

  .project_list > ul {
    grid-template-columns: repeat(1, 1fr);
    padding-bottom: 0;
  }
  .project_list > ul > li:nth-child(even) {
    top: 0;
  }

  .article_ttl {
    font-size: 5.5vw;
    line-height: 1.2;
  }
  .notes .text_en {
    line-height: 1.6;
  }
  .intro_head {
    margin-bottom: var(--margin-60);
  }
  .intro_ttl_shoulder {
    font-size: 3.2vw;
  }
  .intro_ttl {
    font-size: 5vw;
  }
  .intro_ttl > span {
    font-size: 3vw;
  }
  .article_column .article_wrap {
    flex-direction: column;
    row-gap: var(--margin-50);
    width: 100%;
  }
  .article_column.reverse .article_wrap,
  #page-about-dna .article_column:nth-child(even) .article_wrap {
    flex-direction: column;
  }
  .article_column .article_wrap > * {
    width: 100%;
  }
  .article_column .article_wrap .article_img figcaption > b {
    font-size: 4vw;
  }
  .article_link {
    text-align: center;
  }
  .article_link > a {
    width: 80%;
    padding: var(--margin-30);
  }
  .article_link > a > span::after {
    width: 2.2vw;
    height: 2.2vw;
  }
  .article_summary {
    margin-top: var(--margin-60);
  }
  .article_summary .text_jp {
    font-size: 3vw;
  }
  .article_more {
    margin-top: 14vw;
  }
  .more_ttl {
    font-size: 5vw;
  }
  .article_more > ul {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--margin-80) var(--margin-30);
  }

  #archive-people > .container > .block + .block {
    margin-top: 14vw;
  }
  .block_ttl {
    font-size: 5.5vw;
  }
  .people_list > ul {
    grid-template-columns: repeat(1, 1fr);
  }
  .people_position > p {
    font-size: 2vw;
    line-height: 1.4;
  }
  .people_position > p + p {
    margin-top: 0.8vw;
  }
  .page_lead .text_en {
    font-size: 3.4vw;
  }
  .page_lead .text_jp {
    font-size: 2vw;
    margin-top: 1vw!important;
  }
  .people_name {
    font-size: 5vw;
  }
  .people_detail > p {
    font-size: 2vw;
    margin-bottom: var(--margin-05);
  }
  .staff_list > ul {
    grid-template-columns: repeat(2, 1fr);
  }
  .staff_position {
    font-size: 2.2vw;
  }
  .staff_name {
    font-size: 3.2vw;
  }
  .staff_area {
    font-size: 2vw;
  }
  #single-people .page_visual img {
    height: 65vw;
  }
  .column_body {
    width: 100%;
  }
  .article_block + .article_block {
    margin-top: var(--margin-100);
  }
  .column_body .article_ttl {
    font-size: 4.5vw;
  }
  .column_side {
    width: 100%;
  }
  .column_side > * + * {
    margin-top: var(--margin-90);
  }
  .side_head {
    margin-bottom: var(--margin-40);
  }
  .side_ttl {
    font-size: 5vw;
  }

  #page-about-office .container {
    width: 100%;
  }
  #page-about-office .column {
    row-gap: var(--margin-60);
  }
  #page-about-office .column + .column {
    margin-top: 14vw;
  }
  .office_head .office_name {
    font-size: 5vw;
  }
  .column .office_detail {
    margin-top: var(--margin-40);
  }
  .column .office_map iframe {
    width: 100%;
  }

  #page-about-visoin .article_column .article_wrap {
    flex-direction: column-reverse;
    row-gap: var(--margin-80);
  }
  #page-about-visoin .article_column .article_wrap > .article_txt {
    width: 100%;
  }
  #page-about-visoin .intro_ttl {
    font-size: 5vw;
  }
  .article_item + .article_item {
    margin-top: var(--margin-80);
  }
  .article_item_ttl {
    font-size: 4.5vw;
  }
  .article_item_ttl::after {
    width: 6vw;
    margin-top: var(--margin-30);
  }
  .article_item_body .article_summary .text_en {
    font-size: calc(var(--font-size-base) + 1px);
  }
  .article_column .article_wrap .article_vision {
    width: 100%;
    height: 80vw;
    background-image: url(../img/about/vision_bg_sp.png);
  }
  .article_vision .vision_block {
    width: 24vw;
    height: 40vw;
  }
  .article_vision .vision_block:nth-child(odd) {
    right: 0;
  }
  .article_vision .vision_block:nth-child(even) {
    left: 0;
  }
  .article_vision .vision_block:first-child {
    right: auto;
  }
  .article_vision .vision_block:nth-child(2) {
    bottom: 0;
    margin-top: auto;
  }
  .article_vision .vision_block:nth-child(3) {
    top: auto;
    bottom: 0;
    left: auto;
    margin-top: 0;
  }
  .article_vision .vision_block > a {
    padding: var(--margin-60) 0;
    pointer-events: auto;
  }
  .article_vision .vision_block .article_item_ttl {
    font-size: 4vw;
    margin-bottom: var(--margin-05);
  }
  .article_vision .vision_block .text_jp {
    line-height: 1.4;
  }
  .article_vision .vision_block .text_jp > br {
    display: block;
  }

  .history_list {
    margin-top: 14vw;
  }
  .history_head {
    margin-bottom: var(--margin-50);
  }
  .history_head_ttl {
    font-size: 8vw;
  }
  .history_scroll {
    font-size: 3.5vw;
    column-gap: var(--margin-30);
  }
  .history_scroll .material-icons {
    font-size: 5vw;
  }
  .history_era {
    font-size: 6vw;
  }
  .history_block {
    height: calc(220px * 2);
  }
  .history_block::after {
    height: 3px;
  }
  .history_item {
    width: 240px;
    height: 220px;
    padding: var(--margin-40) var(--margin-40) var(--margin-40);
  }
  .history_item:nth-child(odd) {
    margin-left: -5vw;
  }
  .history_item:first-child {
    margin-left: 5vw;
  }
  .history_item:nth-child(2) {
    margin-left: 10vw;
  }
  .history_year {
    font-size: 3.8vw;
  }
  .history_detail .text_en {
    font-size: var(--font-size-s);
  }
  .history_img img {
    height: 20vw;
  }

  #page-awards .wrap {
    overflow: scroll;
  }
  .awards_list {
    width: 860px;
  }
  .awards_list_body > li > p > a::after {
    width: 2.2vw;
    height: 2.2vw;
  }
  .awards_list .icon img {
    height: 12px;
    vertical-align: middle;
  }

  .page_intro {
    margin-bottom: var(--margin-100);
  }
  .page_intro .intro_ttl {
    font-size: 5vw;
  }
  .page_table .table {
    row-gap: var(--margin-60);
  }
  .page_table .table .text_en {
    line-height: 1.6;
  }
  .page_table .table .text_jp {
    font-size: var(--font-size-xs);
  }
  .page_foot {
    width: 100%;
    max-width: 100%;
  }
  .page_foot .text_jp {
    line-height: 1.4;
  }
  .page_foot .btn_submit {
    margin-top: var(--margin-50);
  }
  .page_foot .btn_submit.confirm > * {
    column-gap: var(--margin-05);
  }
  .page_foot .btn_submit > a, .page_foot .btn_submit input[type="submit"],
  .page_foot .btn_submit > a, .page_foot .btn_submit input[type="button"] {
    padding: var(--margin-35);
    font-size: var(--font-size-base);
  }

  .page_intro .column_head {
    width: 100%;
  }
  .page_intro .column {
    row-gap: var(--margin-30);
  }
  .page_intro .column + .column {
    margin-top: var(--margin-50);
  }
  .page_intro .column_body .text_en > strong {
    font-size: 8vw;
  }
  .page_intro .column_head .text_en + .text_jp {
    margin-top: var(--margin-05);
  }
  .page_form .page_table .table {
    grid-template-columns: repeat(1, 1fr);
    row-gap: var(--margin-20);
  }
  .page_form .page_table .table > dt:first-of-type {
    border-bottom: none;
    padding-bottom: 0;
  }
  .page_form .page_table .table > dd:first-of-type {
    padding-bottom: var(--margin-50);
  }
  .page_form .page_table .table dd + dt {
    margin-top: var(--margin-30);
  }
  .page_form .form_wrap {
    margin-top: var(--margin-20);
  }
  .page_form .form_label + .form_label {
    margin-top: var(--margin-30);
  }
  .page_form .form_wrap .wpcf7-radio {
    row-gap: var(--margin-30);
  }
  .page_form .form_wrap input[type="radio"] {
    width: 4vw;
    height: 4vw;
    margin-right: var(--margin-10);
  }
  .page_form .form_wrap .wpcf7-radio .wpcf7-list-item-label {
    line-height: 1;
  }
  #page-contact .page_table .table .text_en {
    line-height: 1;
  }
  #page-contact .page_table .table .text_jp {
    line-height: 1;
  }
  #page-contact .page_form .form_notes .text_en,
  #page-contact .page_form .form_notes .text_jp {
    line-height: 1.4;
  }
  .page_form .form_notes .text_en {
    font-size: var(--font-size-xs);
  }
  .page_form .form_notes .text_jp {
    font-size: calc(var(--font-size-xs) - 1px);
  }
  .page_form input[type="text"],
  .page_form input[type="email"],
  .page_form input[type="tel"],
  .page_form textarea {
    font-size: 16px;
  }
  .page_box .box_ttl {
    font-size: var(--font-size-base);
  }
  .page_box .box_head > p {
    font-size: var(--font-size-xs);
  }
  .page_box > * + * {
    margin-top: var(--margin-40);
  }
  .page_box .table {
    grid-template-columns: repeat(1, 1fr);
    row-gap: var(--margin-30);
  }
  .page_box .table > dt {
    border-top: 1px solid #ccc;
    padding-top: var(--margin-30);
  }
  .page_box .text_en {
    line-height: 1.4;
  }
  .page_box + .page_foot {
    margin-top: var(--margin-60);
  }
  .page_foot .form_label {
    margin-bottom: var(--margin-40);
  }
  #page-contact .wpcf7 form .wpcf7-response-output {
    text-align: center;
  }
  
  #footer {
    padding-top: var(--margin-80);
    padding-bottom: var(--margin-80);
  }
  #footer a {
    color: var(--color-white);
  }
  #footer > .wrap {
    flex-direction: column;
    row-gap: var(--margin-60);
  }
  .footer_main .logo svg {
    width: 24.5vw;
    height: 5.5vw;
  }
  .footer_main .sns {
    margin-top: var(--margin-30);
  }
  .footer_main .sns svg {
    width: 4vw;
    height: 4vw;
  }
  .footer_menu {
    display: none;
  }
  .footer_info > p {
    font-size: 3vw;
  }
  .copyright {
    margin-top: var(--margin-80);
    font-size: 2vw;
  }
}