@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Zen+Old+Mincho:wght@400;500;600;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
/* CSS Document */
html,
body,
header,
footer,
main,
nav,
section,
article,
h1,
h2,
h3,
h4,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
input,
textarea,
button,
figure,
blockquote {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: inherit;
  font-size: 100%;
  line-height: 1;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

span {
  font-weight: inherit;
}

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

body {
  line-height: 1;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

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

ol,
ul {
  list-style: none;
  list-style-type: none;
  padding: 0;
}

a {
  text-decoration: none;
}

address,
cite {
  font-style: normal;
}

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

em {
  font-weight: normal;
  font-size: 100%;
  font-style: normal;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

/*iOS*/
/* iOSでのデフォルトスタイルをリセット */
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}

.font-medium {
  font-weight: 500;
}
.font-bold {
  font-weight: 700;
}
.font-bold2 {
  font-weight: 900;
}

/* 共通スタイル ==================================================*/
html {
  overflow-x: hidden;
  font-size: 62.5%;
  scroll-behavior: smooth;
  scroll-padding: 88px;
}

body {
  position: relative;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "MS PMincho", serif;
  font-weight: 400;
  color: #070707;
  overflow-x: hidden;
  overflow-y: auto;
  font-size: 16px;
  font-size: 1.6rem;
  font-size: clamp(1.2rem, 1.0342541436rem + 0.4419889503vw, 1.6rem);
}

body {
  opacity: 0;
  transition: opacity 0.8s ease;
}
body.loaded {
  opacity: 1;
}

main {
  position: relative;
}

p {
  line-height: 1.5em;
  font-weight: 400;
  font-feature-settings: "palt";
}

strong {
  font-weight: inherit;
}

.t-red {
  color: #d80f0f;
}

img {
  max-width: 100%;
  pointer-events: none;
}

.cover_1500 {
  position: relative;
  width: 80%;
  margin: 0 auto;
}
@media print, screen and (min-width: 1280px) {
  .cover_1500 {
    /*TB*/
    max-width: 1500px;
  }
}

.cover_1200 {
  position: relative;
  width: 80%;
  margin: 0 auto;
}
@media print, screen and (min-width: 1280px) {
  .cover_1200 {
    /*TB*/
    max-width: 1200px;
  }
}

.cover_1024 {
  position: relative;
  width: 80%;
  margin: 0 auto;
}
@media print, screen and (min-width: 1280px) {
  .cover_1024 {
    /*TB*/
    max-width: 1024px;
  }
}

.cover_900 {
  position: relative;
  width: 80%;
  margin: 0 auto;
}
@media print, screen and (min-width: 1280px) {
  .cover_900 {
    /*TB*/
    max-width: 900px;
  }
}

a {
  color: inherit;
  font-weight: inherit;
  /*マウスオーバー切り替え秒数*/
  -webkit-transition: 0.5s;
  -moz-transition: 0.5s;
  -o-transition: 0.5s;
  -ms-transition: 0.5s;
  transition: 0.5s;
}
a::before, a::after {
  transition: 0.5s;
}
a img {
  /*マウスオーバー切り替え秒数*/
  -webkit-transition: 0.5s;
  -moz-transition: 0.5s;
  -o-transition: 0.5s;
  -ms-transition: 0.5s;
  transition: 0.5s;
}
a:hover img {
  opacity: 0.7;
}
@media print, screen and (min-width: 768px) {
  a[href^="tel:"] {
    /*TB*/
    pointer-events: none;
  }
}

/* メインコンテンツ ================================================== */
.section {
  position: relative;
  padding: 6rem 0;
}
@media print, screen and (min-width: 1280px) {
  .section {
    /*TB*/
    padding: 10rem 0;
  }
  #toppage .section {
    padding: 18rem 0;
  }
}

.sp-none {
  display: none;
}

@media print, screen and (min-width: 768px) {
  /*TB*/
  .sp-none {
    display: inherit;
  }
  .sp-only {
    display: none;
  }
}
.commingsoon {
  padding: 10vw 0;
}
.commingsoon p {
  font-size: clamp(1.6rem, 0.6055248619rem + 2.6519337017vw, 4rem);
  text-align: center;
}

.contents-header {
  position: relative;
  width: 100%;
  height: max(480px, 31.25vw);
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
}
.contents-header hgroup {
  writing-mode: vertical-rl;
  color: #0c1e04;
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  font-size: clamp(2.4rem, 2.1513812155rem + 0.6629834254vw, 3rem);
}
.contents-header hgroup .eng-title {
  font-size: 0.5em;
  height: 100%;
}

hgroup.h2_group {
  writing-mode: vertical-rl;
  color: #0c1e04;
  display: flex;
  flex-flow: column wrap;
  align-self: flex-start;
  justify-content: center;
}
hgroup.h2_group .eng-title {
  font-size: clamp(1.8rem, 1.4685082873rem + 0.8839779006vw, 2.6rem);
}
hgroup.h2_group:has(.link_btn) h2 {
  margin-bottom: 1em;
}
hgroup.h2_group h2 {
  font-size: clamp(3.2rem, 2.2883977901rem + 2.4309392265vw, 5.4rem);
}
hgroup.h2_group .link_btn {
  display: inline-block;
  border: solid 0.1rem #0c1e04;
  padding: 0.5em;
  font-size: clamp(1.2rem, 1.0342541436rem + 0.4419889503vw, 1.6rem);
  margin-top: 3em;
}
@media print, screen and (min-width: 1280px) {
  hgroup.h2_group .link_btn {
    /*TB*/
  }
  hgroup.h2_group .link_btn:hover {
    background-color: #0c1e04;
    color: #FFF;
  }
  hgroup.h2_group .link_btn:hover .arrow::before, hgroup.h2_group .link_btn:hover .arrow::after {
    background-color: #FFF;
  }
}
hgroup.h2_group .arrow {
  position: relative;
  display: inline-block;
  width: 1.5em;
  height: 2em;
}
hgroup.h2_group .arrow::before, hgroup.h2_group .arrow::after {
  position: absolute;
  display: block;
  content: "";
  height: 0.1rem;
  background-color: #0c1e04;
  bottom: 30%;
  transition: 0.5s;
}
hgroup.h2_group .arrow::before {
  width: 100%;
  left: 0;
}
hgroup.h2_group .arrow::after {
  width: 40%;
  transform: rotate(45deg);
  transform-origin: right bottom;
}

h3 {
  font-size: clamp(2rem, 1.6685082873rem + 0.8839779006vw, 2.8rem);
  margin-bottom: 0.5em;
}

.tategaki {
  writing-mode: vertical-rl;
}

.flex_area {
  display: flex;
  flex-flow: row wrap;
  gap: 2rem;
  align-items: flex-start;
}
@media print, screen and (min-width: 768px) {
  .flex_area {
    /*TB*/
    gap: 3rem;
  }
}
@media print, screen and (min-width: 1280px) {
  .flex_area {
    /*TB*/
    flex-flow: row nowrap;
  }
}

.inner.flex {
  display: flex;
  flex-flow: row wrap;
}
.inner.flex_reverse {
  display: flex;
  flex-flow: row wrap;
}
@media print, screen and (min-width: 1280px) {
  .inner.flex_reverse {
    /*TB*/
    flex-flow: row-reverse wrap;
  }
}
.inner.flex_column {
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
}

dl.table {
  max-width: 880px;
  display: flex;
  flex-flow: row wrap;
}
dl.table dt,
dl.table dd {
  width: 100%;
  line-height: 1.5;
  padding: 0.5em 0;
}
@media print, screen and (min-width: 1280px) {
  dl.table dt,
  dl.table dd {
    /*TB*/
    padding: 1em 0;
  }
}
dl.table dt {
  font-weight: bold;
}
@media print, screen and (min-width: 768px) {
  dl.table dt {
    /*TB*/
    width: 22%;
  }
}
dl.table dd {
  margin-bottom: 2rem;
}
@media print, screen and (min-width: 768px) {
  dl.table dd {
    /*TB*/
    width: 78%;
  }
}

.link_area {
  text-align: center;
  padding: 0 0 8rem;
  margin-top: 5rem;
}
@media print, screen and (min-width: 1280px) {
  .link_area {
    /*TB*/
    margin-top: 10rem;
  }
}
.link_area .link_btn {
  writing-mode: vertical-rl;
  display: inline-block;
  border: solid 0.1rem #0c1e04;
  padding: 1em 0.8em;
  font-size: clamp(1.4rem, 1.2342541436rem + 0.4419889503vw, 1.8rem);
  background-color: #FFF;
  cursor: pointer;
  transition: 0.5s;
}
.link_area .link_btn.yoko {
  writing-mode: inherit;
  padding: 0.8em 2em;
}
.link_area .link_btn.yoko .arrow {
  height: 1.2em;
  width: 2em;
  vertical-align: middle;
  margin-left: 2em;
  transition: 0.3s;
}
.link_area .link_btn.yoko .arrow::before, .link_area .link_btn.yoko .arrow::after {
  bottom: 50%;
}
.link_area .link_btn.yoko .arrow::after {
  right: 0;
}
@media print, screen and (min-width: 1280px) {
  .link_area .link_btn.yoko {
    /*TB*/
  }
  .link_area .link_btn.yoko:hover .arrow {
    transform: translateX(1em);
  }
}
.link_area .link_btn:hover {
  background-color: #0c1e04;
  color: #FFF;
}
.link_area .link_btn:hover .arrow::before, .link_area .link_btn:hover .arrow::after {
  background-color: #FFF;
}
.link_area .arrow {
  position: relative;
  display: inline-block;
  width: 1.2em;
  height: 2em;
}
.link_area .arrow::before, .link_area .arrow::after {
  position: absolute;
  display: block;
  content: "";
  height: 0.1rem;
  background-color: #0c1e04;
  bottom: 30%;
  transition: 0.5s;
}
.link_area .arrow::before {
  width: 100%;
  left: 0;
}
.link_area .arrow::after {
  width: 40%;
  transform: rotate(45deg);
  transform-origin: right bottom;
}

#lightcase-overlay {
  background: #fff;
  opacity: 0.9 !important;
}

#lightcase-case {
  text-shadow: none;
}

#lightcase-content {
  box-shadow: none !important;
}

a[class*=lightcase-icon-],
a[class*=lightcase-icon-]:focus {
  color: rgba(51, 51, 51, 0.6);
}

a[class*=lightcase-icon-]:hover {
  color: #333;
}

html.lightcase-open {
  overflow: hidden !important;
}

/*---------------------------------------------------
メインメニュー
----------------------------------------------------*/
html:has(#header.menu-open),
body:has(#header.menu-open) {
  overflow: hidden;
}
html:has(#header.menu-open) #global-navi_area,
body:has(#header.menu-open) #global-navi_area {
  display: flex;
}

#header {
  position: fixed;
  top: 0;
  width: 100%;
  max-width: 100vw;
  transition: background-color 0.3s;
  padding: 2rem;
}
@media print, screen and (min-width: 1280px) {
  #header {
    /*TB*/
    padding: 3rem;
  }
}
#header.menu-open {
  backdrop-filter: blur(2px);
  height: 100vh;
  height: 100dvh;
  overflow-y: scroll;
  background-color: rgba(244, 244, 244, 0.75);
}
#header.menu-open #menu-trigger span:nth-of-type(1) {
  top: calc(50% - 0.8rem);
  transform-origin: 50% 50%;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}
#header.menu-open #menu-trigger span:nth-of-type(2) {
  opacity: 0;
}
#header.menu-open #menu-trigger span:nth-of-type(3) {
  top: calc(50% - 0.8rem);
  transform-origin: 50% 50%;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
#header.menu-open #menu-trigger p.menu {
  display: none;
}
#header.menu-open #menu-trigger p.close {
  display: block;
}
#toppage #header.menu-open #menu-trigger span {
  background-color: #0c1e04;
}
#toppage #header.menu-open #menu-trigger p {
  color: #0c1e04;
}

/*---------------------------------------------------
ハンバーガーメニュー
-------------------------------------------------*/
#menu-trigger {
  display: block;
  position: absolute;
  top: 2rem;
  right: 2rem;
  text-align: center;
}
@media print, screen and (min-width: 768px) {
  #menu-trigger {
    /*TB*/
    top: 3rem;
    right: 3rem;
  }
}
#menu-trigger a,
#menu-trigger span {
  display: inline-block;
  transition: all 0.4s;
}
#menu-trigger a {
  position: relative;
  width: 4rem;
  height: 5rem;
}
#menu-trigger a:hover {
  cursor: pointer;
}
#menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #0c1e04;
  border-radius: 5px;
}
#menu-trigger span:nth-of-type(1) {
  top: 0;
}
#menu-trigger span:nth-of-type(2) {
  top: 1.54rem;
}
#menu-trigger span:nth-of-type(3) {
  bottom: 1.92rem;
}
#menu-trigger p {
  position: absolute;
  width: 100%;
  bottom: 0;
  color: #0c1e04;
  text-align: center;
  line-height: 1.2;
  font-size: clamp(1.4rem, 1.3585635359rem + 0.1104972376vw, 1.5rem);
}
#menu-trigger p.menu {
  display: block;
}
#menu-trigger p.close {
  display: none;
}

#toppage .wt-tgl #menu-trigger span {
  background-color: #FFF;
}
#toppage .wt-tgl #menu-trigger p {
  color: #FFF;
}

/*---------------------------------------------------
グローバルメニュー
-------------------------------------------------*/
#global-navi_area {
  position: relative;
  overflow: hidden;
  max-width: 1500px;
  margin: 0 auto;
  padding: 8rem 0 0;
  min-height: max-content;
  min-height: calc(100vh - 4rem);
  min-height: calc(100dvh - 4rem);
  flex-flow: column nowrap;
}
@media print, screen and (min-width: 1280px) {
  #global-navi_area {
    /*TB*/
    height: 100%;
    padding: 8rem 0;
  }
}
#global-navi_area .main-nav {
  position: relative;
  display: flex;
  flex-flow: row-reverse nowrap;
  align-items: flex-start;
  justify-content: flex-start;
  margin-bottom: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #global-navi_area .main-nav {
    /*TB*/
    margin-bottom: 0;
  }
}
#global-navi_area .main-nav #site-name {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  writing-mode: vertical-rl;
  letter-spacing: 0.1em;
}
#global-navi_area .main-nav #site-name img {
  width: 5.5rem;
  margin-bottom: 0.5em;
}
#global-navi_area .main-nav #site-name h1 {
  font-size: clamp(1.6rem, 1.1027624309rem + 1.3259668508vw, 2.8rem);
}
#global-navi_area .main-nav #site-name h1 strong {
  font-size: 1.28em;
}
#global-navi_area .main-nav > .menu {
  display: flex;
  flex-flow: row-reverse wrap;
  padding: 4rem 0 0;
  gap: 2em;
  margin-right: 4rem;
}
#global-navi_area .main-nav > .menu > li {
  position: relative;
  writing-mode: vertical-rl;
}
#global-navi_area .main-nav > .menu > li a {
  font-size: clamp(1.5rem, 0.8784530387rem + 1.6574585635vw, 3rem);
}
#global-navi_area .main-nav > .menu > li a:hover {
  color: #537946;
}
#global-navi_area .main-nav > .menu > li span {
  display: block;
  font-size: 0.5em;
  margin-left: 0.5em;
}
#global-navi_area .sub-nav {
  display: flex;
  flex-flow: column nowrap;
  gap: 1.5rem;
  margin-top: auto;
}
@media print, screen and (min-width: 1280px) {
  #global-navi_area .sub-nav {
    /*TB*/
    position: absolute;
    left: 0;
    bottom: 5vh;
  }
}
#global-navi_area .sub-nav .menu_tel {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  line-height: 1.2;
}
#global-navi_area .sub-nav .menu_tel a {
  display: block;
  font-size: clamp(2rem, 1.3370165746rem + 1.7679558011vw, 3.6rem);
}
#global-navi_area .sub-nav address {
  line-height: 1.5;
}
#global-navi_area .sub-nav .menu_privacy {
  line-height: 1;
}
#global-navi_area .sub-nav .menu_privacy a:hover {
  color: #537946;
}
#global-navi_area .sub-nav .link_list {
  display: flex;
  flex-flow: row wrap;
  gap: 2rem;
}
#global-navi_area .sub-nav .link_list li {
  width: 4rem;
}
#global-navi_area .sub-nav .link_list li a {
  display: block;
  text-align: center;
}

body#toppage #header .menu .menu_home a {
  color: #537946;
}
body#about #header .menu .menu_about a {
  color: #537946;
}
body#news #header .menu .menu_news a {
  color: #537946;
}
body#service #header .menu .menu_service a {
  color: #537946;
}
body#works #header .menu .menu_works a {
  color: #537946;
}
body#company #header .menu .menu_company a {
  color: #537946;
}
body#contact #header .menu .menu_contact a {
  color: #537946;
}
body#recruit #header .menu .menu_recruit a {
  color: #537946;
}
body#partner #header .menu .menu_partner a {
  color: #537946;
}

/* フッター ------------------- */
#footer {
  position: relative;
  width: 100%;
  background-color: #f1f3f1;
}
#footer #footer-navi_area {
  position: relative;
  margin: 0 auto;
  padding: 4rem 0;
}
@media print, screen and (min-width: 1280px) {
  #footer #footer-navi_area {
    /*TB*/
    padding: 8rem 0;
  }
}
#footer #footer-navi_area .main-nav {
  position: relative;
  display: flex;
  flex-flow: row wrap;
  align-items: flex-start;
  justify-content: flex-start;
}
@media print, screen and (min-width: 1280px) {
  #footer #footer-navi_area .main-nav {
    /*TB*/
    flex-flow: row-reverse nowrap;
  }
}
#footer #footer-navi_area .main-nav #site-name {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  letter-spacing: 0.1em;
  margin-bottom: 2rem;
}
@media print, screen and (min-width: 1280px) {
  #footer #footer-navi_area .main-nav #site-name {
    /*TB*/
    writing-mode: vertical-rl;
  }
}
#footer #footer-navi_area .main-nav #site-name img {
  width: 5.5rem;
  margin-bottom: 0.5em;
}
#footer #footer-navi_area .main-nav #site-name h1 {
  font-size: clamp(1.6rem, 1.1027624309rem + 1.3259668508vw, 2.8rem);
}
#footer #footer-navi_area .main-nav #site-name h1 strong {
  font-size: 1.28em;
}
#footer #footer-navi_area .main-nav > .menu {
  display: none;
  padding: 4rem 0 0;
  gap: 2em;
  margin-right: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #footer #footer-navi_area .main-nav > .menu {
    /*TB*/
    display: flex;
    flex-flow: row-reverse nowrap;
  }
}
#footer #footer-navi_area .main-nav > .menu > li {
  position: relative;
  writing-mode: vertical-rl;
}
#footer #footer-navi_area .main-nav > .menu > li a {
  font-size: clamp(1.5rem, 1.1270718232rem + 0.9944751381vw, 2.4rem);
}
#footer #footer-navi_area .main-nav > .menu > li a:hover {
  color: #537946;
}
#footer #footer-navi_area .main-nav > .menu > li span {
  display: block;
  font-size: 0.5em;
  margin-left: 0.5em;
}
#footer #footer-navi_area .sub-nav {
  display: flex;
  flex-flow: column nowrap;
  gap: 1.5rem;
}
@media print, screen and (min-width: 1280px) {
  #footer #footer-navi_area .sub-nav {
    /*TB*/
    position: absolute;
    left: 0;
    bottom: 5vh;
  }
}
#footer #footer-navi_area .sub-nav .menu_tel {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  line-height: 1.2;
}
#footer #footer-navi_area .sub-nav .menu_tel a {
  display: block;
  font-size: clamp(2rem, 1.3370165746rem + 1.7679558011vw, 3.6rem);
}
#footer #footer-navi_area .sub-nav address {
  line-height: 1.5;
}
#footer #footer-navi_area .sub-nav .menu_privacy {
  line-height: 1;
}
#footer #footer-navi_area .sub-nav .menu_privacy a:hover {
  color: #537946;
}
#footer #footer-navi_area .sub-nav .link_list {
  display: flex;
  flex-flow: row wrap;
  gap: 2rem;
}
#footer #footer-navi_area .sub-nav .link_list li {
  width: 4rem;
}
#footer #footer-navi_area .sub-nav .link_list li a {
  display: block;
  text-align: center;
}
#footer .copy {
  width: 100%;
  padding: 1rem 0;
}
#footer .copy p {
  text-align: center;
  font-size: 1.4rem;
}

.goTop {
  position: fixed;
  right: 0;
  bottom: 0;
}
.goTop a {
  position: relative;
  height: 100%;
  width: 4rem;
  display: block;
  cursor: pointer;
}
@media print, screen and (min-width: 768px) {
  .goTop a {
    /*TB*/
    width: 6rem;
  }
}

/* フェードしたい要素に付与するクラス */
.inview {
  opacity: 0;
  transform: translateY(50px);
  transition: 1s;
}

/* 時間差フェードで付与するクラス */
.fadeDelay05 {
  transition-delay: 0.5s;
}

.fadeDelay10 {
  transition-delay: 1s;
}

.fadeDelay15 {
  transition-delay: 1.5s;
}

/* フェードしたい要素に付与するクラス */
.show {
  opacity: 1;
  transform: translateY(0px);
}

.modal-mode {
  overflow: hidden;
}

.modal-content {
  position: fixed;
  display: none;
  z-index: 2;
  z-index: 1000;
  width: 90%;
  margin: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  max-height: 80vh;
  overflow: hidden;
  border-radius: 3rem;
}
@media print, screen and (min-width: 1280px) {
  .modal-content {
    /*TB*/
    width: 75%;
  }
}
@media print, screen and (min-width: 1401px) {
  .modal-content {
    /*PC*/
    width: 50%;
  }
}
.modal-content .modal-content_inner {
  padding: 1.5em 2em;
  overflow-y: auto;
  max-height: 70vh;
}
@media print, screen and (min-width: 768px) {
  .modal-content .modal-content_inner {
    /*TB*/
    padding: 3em 4em;
  }
}

.modal-open {
  cursor: pointer;
}

.modal-overlay {
  z-index: 1;
  z-index: 999;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 120%;
  background-color: rgba(7, 7, 7, 0.75);
}

.modal-close {
  display: block;
  position: absolute;
  right: 1em;
  top: 1em;
}
.modal-close::before {
  display: block;
  content: "×";
  font-size: 2em;
  text-align: center;
  line-height: 1em;
  width: 1em;
}
.modal-close:hover {
  cursor: pointer;
  opacity: 0.7;
}

#header {
  z-index: 998;
}

#menu-trigger {
  z-index: 999;
}

#toppage_works article .works-title {
  z-index: 2;
}
#toppage_works article picture {
  z-index: 1;
}

#toppage_service .h2_group {
  z-index: 1;
}

#works .works_list article p {
  z-index: 2;
}
#works .works_list article picture {
  z-index: 1;
}

/* ================================
トップページ トップ
================================*/
.keyvisual_area {
  position: relative;
  width: 100%;
  margin: 0 auto;
  min-height: 100vh;
  max-height: 100vh;
  max-height: 100dvh;
  height: 100dvh;
  overflow: hidden;
}
.keyvisual_area::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
  left: 0;
  top: 0;
  z-index: 1;
}
.keyvisual_area p {
  position: absolute;
  bottom: 2em;
  left: 1em;
  color: #FFF;
  writing-mode: vertical-rl;
  font-size: clamp(3rem, 2.2541436464rem + 1.9889502762vw, 4.8rem);
  z-index: 2;
  font-size: clamp(3rem, 6vh, 48rem);
}
@media print, screen and (min-width: 1280px) {
  .keyvisual_area p {
    /*TB*/
    bottom: 3em;
    left: 2em;
  }
}
.keyvisual_area p strong {
  font-size: 1.2em;
}
.keyvisual_area video {
  min-width: 100%;
  min-height: 100vh;
  min-height: 100dvh;
}

#toppage_news .flex_reverse {
  justify-content: center;
}
@media print, screen and (min-width: 1280px) {
  #toppage_news .flex_reverse {
    /*TB*/
    gap: 6rem;
  }
}
#toppage_news .h2_group {
  width: 100%;
  align-content: center;
}
@media print, screen and (min-width: 1280px) {
  #toppage_news .h2_group {
    /*TB*/
    width: auto;
  }
}
#toppage_news .news_list {
  width: 80%;
  max-width: 80rem;
  align-self: center;
}
#toppage_news .news_list article {
  padding: 2rem;
}
#toppage_news .news_list article:not(:last-of-type) {
  border-bottom: solid 0.1rem #f1f3f1;
}
#toppage_news .news_list article a:hover {
  opacity: 0.6;
}
#toppage_news .news_list article span {
  display: inline-block;
  margin-right: 1em;
  font-size: clamp(1.4rem, 1.3171270718rem + 0.2209944751vw, 1.6rem);
}
#toppage_news .news_list article p {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  margin-top: 0.5em;
}

#toppage_works .inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .inner {
    /*TB*/
    justify-content: space-between;
    padding: 0 6rem;
    padding: 0 3.125vw;
  }
}
@media print, screen and (min-width: 1401px) {
  #toppage_works .inner {
    /*PC*/
  }
}
#toppage_works .h2_group {
  width: max-content;
}
#toppage_works .works_list {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 4rem;
  width: 100%;
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .works_list {
    /*TB*/
    max-width: 88%;
    gap: 6rem;
  }
}
@media print, screen and (min-width: 768px) {
  #toppage_works .works_list article {
    /*TB*/
    width: calc((100% - 4rem) / 2);
  }
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .works_list article {
    /*TB*/
    width: calc((100% - 12rem) / 3);
    max-width: 320px;
  }
}
#toppage_works .works_list article a {
  display: block;
  position: relative;
}
#toppage_works .works_list article a .works-title {
  writing-mode: vertical-rl;
  position: absolute;
  padding: 1em 0.6em;
  background-color: rgba(255, 255, 255, 0.8);
  top: 0;
  right: 0;
  font-size: clamp(1.8rem, 1.5513812155rem + 0.6629834254vw, 2.4rem);
  transition: 0.5s;
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .works_list article a .works-title {
    /*TB*/
    background-color: #FFF;
  }
}
#toppage_works .works_list article a figure {
  display: block;
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .works_list article a figure {
    /*TB*/
    aspect-ratio: 320/460;
  }
}
#toppage_works .works_list article a figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 1280px) {
  #toppage_works .works_list article a:hover {
    /*TB*/
  }
  #toppage_works .works_list article a:hover .works-title {
    background-color: rgba(255, 255, 255, 0.6);
  }
  #toppage_works .works_list article a:hover img {
    transform: scale(1.2);
    opacity: 1;
  }
}

@media print, screen and (min-width: 768px) {
  #toppage_service {
    /*TB*/
    margin: 5rem 0;
  }
}
@media print, screen and (min-width: 1280px) {
  #toppage_service {
    /*TB*/
    margin: 10rem 0;
  }
}
#toppage_service .service-link {
  position: relative;
  display: flex;
  flex-flow: row nowrap;
  flex-flow: row wrap;
  justify-content: center;
}
@media print, screen and (min-width: 1280px) {
  #toppage_service .service-link {
    /*TB*/
  }
}
#toppage_service .service-link figure {
  position: relative;
  width: 100%;
  aspect-ratio: 2/1;
  overflow: hidden;
}
@media print, screen and (min-width: 768px) {
  #toppage_service .service-link figure {
    /*TB*/
    position: absolute;
    width: 34rem;
    max-width: 30%;
    aspect-ratio: 340/480;
  }
}
@media print, screen and (min-width: 768px) {
  #toppage_service .service-link figure.image_garden {
    /*TB*/
    left: 0;
    bottom: -5rem;
  }
}
@media print, screen and (min-width: 1280px) {
  #toppage_service .service-link figure.image_garden {
    /*TB*/
    bottom: -10rem;
  }
}
@media print, screen and (min-width: 768px) {
  #toppage_service .service-link figure.image_exterior {
    /*TB*/
    right: 0;
    top: -5rem;
  }
}
@media print, screen and (min-width: 1280px) {
  #toppage_service .service-link figure.image_exterior {
    /*TB*/
    top: -10rem;
  }
}
#toppage_service .service-link figure a {
  display: block;
}
#toppage_service .service-link figure a img {
  width: 100%;
}
#toppage_service .service-link figure a:hover img {
  transform: scale(1.2);
}
#toppage_service .service-link .h2_group {
  position: relative;
  max-width: 30%;
  margin: 3em;
  transition: 0.5s;
}
@media print, screen and (min-width: 768px) {
  #toppage_service .service-link .h2_group {
    /*TB*/
    margin: 0;
  }
}
@media print, screen and (min-width: 1280px) {
  #toppage_service .service-link .h2_group {
    /*TB*/
    padding: 2rem 2rem 1rem 3rem;
  }
}
#toppage_service .service-link .h2_group .arrow {
  width: 1em;
}
#toppage_service .service-link .h2_group a {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
@media print, screen and (min-width: 1280px) {
  #toppage_service .service-link .h2_group {
    /*TB*/
  }
  #toppage_service .service-link .h2_group::after {
    content: "";
    display: block;
    position: absolute;
    width: 0%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: #f1f3f1;
    transition: 0.5s;
    z-index: -1;
  }
  #toppage_service .service-link .h2_group:hover::after {
    width: 100%;
  }
}

#toppage_philosophy_box {
  gap: 4rem;
}
#toppage_philosophy .right_area,
#toppage_philosophy .left_area {
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #toppage_philosophy .right_area,
  #toppage_philosophy .left_area {
    /*TB*/
    width: calc(50% - 2rem);
  }
}
#toppage_philosophy .right_area {
  justify-content: space-between;
}
#toppage_philosophy .right_area p {
  font-size: clamp(2.4rem, 1.9027624309rem + 1.3259668508vw, 3.6rem);
}
@media print, screen and (min-width: 1280px) {
  #toppage_philosophy .right_area {
    /*TB*/
    gap: 8rem;
  }
}
#toppage_philosophy .left_area {
  display: flex;
  flex-flow: column wrap;
  justify-content: space-around;
}
@media print, screen and (min-width: 1280px) {
  #toppage_philosophy .left_area {
    /*TB*/
    gap: 0;
  }
}
#toppage_philosophy .left_area p {
  font-size: clamp(1.8rem, 1.5513812155rem + 0.6629834254vw, 2.4rem);
  max-width: 66rem;
  font-feature-settings: "palt";
  line-height: 2;
}
#toppage_philosophy .arrow_link a {
  position: relative;
  display: block;
  width: 100%;
  font-size: clamp(1.6rem, 1.5171270718rem + 0.2209944751vw, 1.8rem);
  padding: 1em;
  letter-spacing: 0.1em;
  font-weight: bold;
  transition: 1s;
}
@media print, screen and (min-width: 768px) {
  #toppage_philosophy .arrow_link a {
    /*TB*/
    width: 24em;
  }
}
#toppage_philosophy .arrow_link a::before, #toppage_philosophy .arrow_link a::after {
  position: absolute;
  display: block;
  content: "";
  background-color: #070707;
  height: 0.1rem;
  bottom: 0;
}
#toppage_philosophy .arrow_link a::before {
  width: 100%;
  left: 0;
}
#toppage_philosophy .arrow_link a::after {
  transform: rotate(45deg);
  transform-origin: right bottom;
  width: 2em;
  right: 0;
}
#toppage_philosophy .arrow_link a:hover {
  width: 100%;
  max-width: 66rem;
}

#about #message .inner {
  width: 100%;
  display: flex;
  flex-flow: row wrap;
  padding: 2rem 0;
  gap: 4rem;
}
@media print, screen and (min-width: 768px) {
  #about #message .inner {
    /*TB*/
    padding: 10rem 0;
    flex-flow: row-reverse wrap;
    gap: 5vw;
  }
}
#about #message h2 {
  font-size: clamp(2.4rem, 1.9027624309rem + 1.3259668508vw, 3.6rem);
  line-height: 1.5;
}
@media print, screen and (min-width: 768px) {
  #about #message h2 {
    /*TB*/
    writing-mode: vertical-rl;
    white-space: nowrap;
  }
}
#about #message p {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  line-height: 2;
}
@media print, screen and (min-width: 768px) {
  #about #message p {
    /*TB*/
    writing-mode: vertical-rl;
    white-space: nowrap;
  }
}
@media print, screen and (min-width: 768px) {
  #about #message p em {
    /*TB*/
    text-combine-upright: all;
    font-style: normal;
  }
}
#about #message figure {
  align-self: flex-end;
}
@media print, screen and (min-width: 768px) {
  #about #message .message_01 p {
    /*TB*/
    margin-top: 10rem;
  }
}
#about #message .message_01 figure {
  margin-right: auto;
}
@media print, screen and (min-width: 768px) {
  #about #message .message_02 {
    /*TB*/
    justify-content: center;
  }
  #about #message .message_02 p {
    order: 2;
  }
  #about #message .message_02 figure {
    order: 1;
  }
}
#about #message .message_03 figure {
  margin-right: auto;
}

#service #garden .inner {
  display: flex;
  flex-flow: row-reverse wrap;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #service #garden .inner {
    /*TB*/
    justify-content: space-between;
  }
}
#service #garden .inner .h2_group {
  margin-left: 5rem;
}
#service #exterior .inner {
  display: flex;
  flex-flow: row wrap;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #service #exterior .inner {
    /*TB*/
    justify-content: space-between;
  }
}
#service #flow .inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
#service .catch {
  font-size: clamp(2.4rem, 1.9027624309rem + 1.3259668508vw, 3.6rem);
  padding-top: 4em;
}
#service .service-guide {
  width: 100%;
  max-width: 800px;
}
@media print, screen and (min-width: 768px) {
  #service .service-guide {
    /*TB*/
    width: 68%;
  }
}
#service .service-guide p {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  margin: 2rem;
}
@media print, screen and (min-width: 768px) {
  #garden #service .service-guide p {
    /*TB*/
    margin: 6rem 0 0 6rem;
  }
}
@media print, screen and (min-width: 768px) {
  #exterior #service .service-guide p {
    /*TB*/
    margin: 6rem 6rem 0 0;
  }
}
#service .service-guide ul {
  margin: 4rem 2rem 2rem;
}
@media print, screen and (min-width: 768px) {
  #garden #service .service-guide ul {
    /*TB*/
    margin: 4rem 0 0 6rem;
  }
}
@media print, screen and (min-width: 768px) {
  #exterior #service .service-guide ul {
    /*TB*/
    margin: 4rem 6rem 0 0;
  }
}
#service .service-guide ul li {
  display: inline-block;
  line-height: 2;
}
#service .service-guide ul li:not(:last-child)::after {
  content: "/";
  padding: 0 0 0 0.3em;
}
#service .flow_area {
  width: 100%;
  margin-top: 4rem;
}
@media print, screen and (min-width: 768px) {
  #service .flow_area {
    /*TB*/
    margin-top: 8rem;
  }
}
#service .flow_area ol {
  counter-reset: flow;
}
#service .flow_area ol li:not(:last-child) {
  margin-bottom: 2em;
}
@media print, screen and (min-width: 768px) {
  #service .flow_area ol li:not(:last-child) {
    /*TB*/
    margin-bottom: 0;
  }
}
@media print, screen and (min-width: 768px) {
  #service .flow_area dl {
    /*TB*/
    display: flex;
    flex-flow: row wrap;
  }
}
#service .flow_area dl dt {
  font-size: clamp(2rem, 1.7513812155rem + 0.6629834254vw, 2.6rem);
  border-bottom: solid 0.1rem #FFF;
  padding: 1rem;
}
#service .flow_area dl dt::before {
  counter-increment: flow 1;
  content: counter(flow) ".";
  padding-right: 0.5em;
}
@media print, screen and (min-width: 768px) {
  #service .flow_area dl dt {
    /*TB*/
    width: 35%;
    padding: 3rem 2rem;
  }
}
#service .flow_area dl dt span {
  font-size: 0.6em;
}
#service .flow_area dl dd {
  font-size: clamp(1.4rem, 1.2342541436rem + 0.4419889503vw, 1.8rem);
  padding: 2rem 1rem;
}
@media print, screen and (min-width: 768px) {
  #service .flow_area dl dd {
    /*TB*/
    width: 65%;
    padding: 3rem 2rem;
    border-bottom: solid 0.1rem #070707;
  }
}
#service .contact_area {
  text-align: center;
  margin-top: 10rem;
}
#service .contact_area .inner {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  border-bottom: solid 0.1rem #070707;
  gap: 2rem;
  padding: 2rem;
  margin-top: 1rem;
}
@media print, screen and (min-width: 768px) {
  #service .contact_area .inner {
    /*TB*/
    flex-flow: row nowrap;
    gap: 4rem;
  }
}
#service .contact_area .inner p {
  font-size: clamp(1.8rem, 1.6342541436rem + 0.4419889503vw, 2.2rem);
}
#service .contact_area .inner p a {
  height: 2em;
}
#service .contact_area .inner p img {
  height: 100%;
  width: auto;
}
#service .contact_area .inner p.tel {
  width: 100%;
}
@media print, screen and (min-width: 768px) {
  #service .contact_area .inner p.tel {
    /*TB*/
    width: auto;
  }
}
#service .contact_area .inner p.tel a {
  font-size: 2em;
  margin-left: 1rem;
}
#service .contact_area .inner p.contact a {
  display: block;
}
#service .contact_area .inner p.line a {
  display: block;
  border: solid 0.1em #070707;
  padding: 1rem;
  height: 5rem;
}

#works .works_list {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #works .works_list {
    /*TB*/
    gap: 22rem 6rem;
  }
}
#works .works_list .work {
  opacity: 0;
  transform: translateY(20px);
  transition: transform 0.5s ease, opacity 0.5s ease;
  display: none;
  /* 初期は非表示 */
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work:nth-of-type(3n) {
    /*TB*/
    margin-top: -5rem;
  }
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work:nth-of-type(3n+2) {
    /*TB*/
    margin-top: 5rem;
  }
}
@media print, screen and (min-width: 768px) {
  #works .works_list .work {
    /*TB*/
    width: calc((100% - 4rem) / 2);
  }
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work {
    /*TB*/
    width: calc((100% - 12rem) / 3);
    max-width: 320px;
  }
}
#works .works_list .work.is-visible {
  display: block;
  opacity: 1;
  transform: translateY(0);
}
#works .works_list .work a {
  display: block;
  position: relative;
}
#works .works_list .work a p {
  writing-mode: vertical-rl;
  position: absolute;
  padding: 1em 0.6em;
}
#works .works_list .work a p.works-title {
  background-color: rgba(255, 255, 255, 0.8);
  top: 0;
  right: 0;
  font-size: clamp(1.8rem, 1.5513812155rem + 0.6629834254vw, 2.4rem);
  transition: 0.5s;
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work a p.works-title {
    /*TB*/
    background-color: #FFF;
  }
}
#works .works_list .work a p.works-subtitle {
  background-color: rgba(12, 30, 4, 0.8);
  color: #FFF;
  font-size: clamp(1.4rem, 1.2342541436rem + 0.4419889503vw, 1.8rem);
  bottom: -2em;
  left: 1em;
}
#works .works_list .work a figure {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work a figure {
    /*TB*/
    aspect-ratio: 320/460;
  }
}
#works .works_list .work a figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 1280px) {
  #works .works_list .work a:hover {
    /*TB*/
  }
  #works .works_list .work a:hover .works-title {
    background-color: rgba(255, 255, 255, 0.6);
  }
  #works .works_list .work a:hover img {
    transform: scale(1.2);
    opacity: 1;
  }
}
#works .works_detail {
  margin-bottom: 10rem;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail {
    /*TB*/
    margin-bottom: 20rem;
  }
}
#works .works_detail .main-box {
  display: flex;
  flex-flow: column wrap;
  gap: 5rem 0;
  margin-bottom: 5rem;
}
@media print, screen and (min-width: 1401px) {
  #works .works_detail .main-box {
    /*PC*/
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: auto;
    grid-auto-flow: row;
    gap: 10rem 0;
    margin-bottom: 10rem;
  }
}
#works .works_detail #hgroup {
  order: 1;
}
@media print, screen and (min-width: 1401px) {
  #works .works_detail #hgroup {
    /*PC*/
    grid-column: 4;
    grid-row: 1;
    justify-content: flex-start;
  }
}
#works .works_detail #gallery {
  width: 100%;
  max-width: 1000px;
  order: 2;
  margin: 0 auto;
}
@media print, screen and (min-width: 1401px) {
  #works .works_detail #gallery {
    /*PC*/
    margin: 0;
    padding: 0 2.6vw;
    grid-column: 1/span 4;
    grid-row: 1;
    order: 0;
  }
}
#works .works_detail #gallery #main-carousel .splide__slide img {
  width: 100%;
  height: 100%;
  max-height: 600px;
  object-fit: contain;
  object-position: center;
  background-color: #f1f3f1;
}
#works .works_detail #gallery #main-carousel p {
  padding: 1em;
}
#works .works_detail #gallery #thumbnail-carousel {
  margin-top: 2rem;
}
#works .works_detail #gallery #thumbnail-carousel .splide__track--nav > .splide__list > .splide__slide {
  width: 100% !important;
}
#works .works_detail #gallery #thumbnail-carousel .splide__track--nav > .splide__list > .splide__slide.is-active {
  width: 100% !important;
}
#works .works_detail #gallery #thumbnail-carousel .splide__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
}
#works .works_detail #gallery #thumbnail-carousel .splide__list .splide__slide {
  aspect-ratio: 3/2;
  overflow: hidden;
}
#works .works_detail #gallery #thumbnail-carousel .splide__list .splide__slide img {
  object-fit: contain;
  object-position: center;
  width: 100%;
  height: 100%;
}
#works .works_detail .other-box {
  display: flex;
  flex-flow: column wrap;
  gap: 5rem 0;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail .other-box {
    /*TB*/
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: auto;
    grid-auto-flow: row;
    gap: 10rem 0;
  }
}
#works .works_detail #concept {
  order: 3;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail #concept {
    /*TB*/
    padding: 0 2.6vw;
    order: 0;
  }
}
#works .works_detail #concept p {
  line-height: 2;
}
#works .works_detail #voice {
  order: 4;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail #voice {
    /*TB*/
    padding: 0 2.6vw;
    order: 0;
  }
}
#works .works_detail #voice p {
  line-height: 2;
}
#works .works_detail #before-after {
  display: flex;
  flex-flow: row wrap;
  gap: 2rem;
  order: 5;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail #before-after {
    /*TB*/
    padding: 0 2.6vw;
    order: 0;
  }
}
#works .works_detail #before-after a {
  display: block;
}
#works .works_detail #before-after #before {
  width: calc(40% - 1rem);
}
#works .works_detail #before-after #before img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#works .works_detail #before-after #after {
  width: calc(60% - 1rem);
  margin-top: 4rem;
}
#works .works_detail #before-after #after img {
  aspect-ratio: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#works .works_detail #movie {
  position: relative;
  width: 100%;
  order: 6;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail #movie {
    /*TB*/
    padding: 0 2.6vw;
    order: 0;
  }
}
#works .works_detail #movie .movie_area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
#works .works_detail #movie iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0px;
  left: 0px;
}
#works .works_detail #info {
  order: 7;
}
@media print, screen and (min-width: 1280px) {
  #works .works_detail #info {
    /*TB*/
    padding: 0 2.6vw;
    order: 0;
  }
}
#works .works_detail #info dl {
  display: flex;
  flex-flow: row wrap;
}
#works .works_detail #info dl dt {
  min-width: 5em;
  width: 25%;
  font-size: clamp(1.5rem, 1.3756906077rem + 0.3314917127vw, 1.8rem);
  border-bottom: solid 0.1rem #f1f3f1;
  padding: 1rem 0;
}
#works .works_detail #info dl dd {
  width: 75%;
  max-width: calc(100% - 7.5rem);
  font-size: clamp(1.4rem, 1.3171270718rem + 0.2209944751vw, 1.6rem);
  border-bottom: solid 0.1rem #f1f3f1;
  padding: 1rem 0 1rem 2rem;
}

#company #profile .inner {
  display: flex;
  flex-flow: row-reverse wrap;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #company #profile .inner {
    /*TB*/
    justify-content: space-between;
  }
}
@media print, screen and (min-width: 768px) {
  #company #profile dl.table {
    /*TB*/
    width: calc(100% - 266px);
  }
}
#company #profile figure {
  text-align: left;
}
#company #profile figure img {
  aspect-ratio: 1;
  max-width: 266px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 1280px) {
  #company #profile figure {
    /*TB*/
    position: absolute;
    bottom: 0;
    right: -5%;
    aspect-ratio: 1/2;
  }
  #company #profile figure img {
    max-width: 200px;
  }
}
#company #access .inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
#company #access .map_area {
  width: 100%;
  margin-top: 6rem;
}
@media print, screen and (min-width: 1280px) {
  #company #access .map_area {
    /*TB*/
    margin-top: 12rem;
  }
}
#company #access .map_area iframe {
  display: block;
  max-width: 1000px;
  height: auto;
  aspect-ratio: 1;
  margin: 0 auto;
  width: 100%;
}
@media print, screen and (min-width: 1280px) {
  #company #access .map_area iframe {
    /*TB*/
    aspect-ratio: 10/5;
  }
}
#company #access .map_area p {
  max-width: 1000px;
  margin: 1em auto;
  text-align: center;
}
#company #history .inner {
  display: flex;
  flex-flow: row wrap;
  gap: 4rem;
}
@media print, screen and (min-width: 1280px) {
  #company #history .inner {
    /*TB*/
    justify-content: space-between;
  }
}
#company #history .inner dl.table {
  max-width: 600px;
  width: max-content;
}
#company #history figure {
  text-align: right;
}
#company #history figure img {
  aspect-ratio: 1;
  max-width: 266px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media print, screen and (min-width: 1280px) {
  #company #history figure {
    /*TB*/
    position: absolute;
    bottom: 0;
    left: -10%;
    aspect-ratio: 1/2;
  }
  #company #history figure img {
    max-width: 200px;
  }
}

#news .news_list {
  display: flex;
  flex-flow: row wrap;
  gap: 5rem;
}
@media print, screen and (min-width: 1280px) {
  #news .news_list {
    /*TB*/
    gap: 10rem 5rem;
  }
}
#news .news_list article {
  width: 100%;
}
@media print, screen and (min-width: 1280px) {
  #news .news_list article {
    /*TB*/
    width: calc((100% - 10rem) / 3);
  }
}
#news .news_list article figure {
  margin-bottom: 2rem;
  background-color: #f1f3f1;
}
#news .news_list article figure a {
  display: block;
  aspect-ratio: 364/225;
  overflow: hidden;
}
#news .news_list article figure a:hover img {
  scale: 1.2;
}
#news .news_list article figure a img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
#news .news_list article p.news-tag {
  font-size: clamp(1.4rem, 1.3171270718rem + 0.2209944751vw, 1.6rem);
  margin-bottom: 0.5em;
}
#news .news_list article p.news-title {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  margin-bottom: 1em;
}
#news .news_list article p.news-date {
  font-size: clamp(1.4rem, 1.3171270718rem + 0.2209944751vw, 1.6rem);
}
#news .news_list article p a:hover {
  opacity: 0.5;
}
#news .pager {
  margin-top: 10rem;
}
#news .pager ol {
  display: flex;
  flex-flow: row wrap;
  gap: 1rem;
  justify-content: center;
}
#news .pager ol li a {
  border: solid 0.1rem #070707;
  padding: 0.5em 1em;
}
#news .news_detail {
  display: flex;
  flex-flow: column nowrap;
  gap: 4rem;
}
#news .news_detail hgroup.h2_group_news {
  color: #0c1e04;
}
#news .news_detail hgroup.h2_group_news .sub-title {
  font-size: clamp(1.8rem, 1.7171270718rem + 0.2209944751vw, 2rem);
  margin-bottom: 1em;
}
#news .news_detail hgroup.h2_group_news .sub-title span {
  margin-right: 1em;
}
#news .news_detail hgroup.h2_group_news h2 {
  font-size: clamp(2.4rem, 1.9027624309rem + 1.3259668508vw, 3.6rem);
}
#news .news_detail .news-message p {
  line-height: 2;
}
#news .news_detail .news-image {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 2rem;
}
@media print, screen and (min-width: 768px) {
  #news .news_detail .news-image {
    /*TB*/
    flex-flow: row nowrap;
    margin-top: 5rem;
  }
}
#news .news_detail .news-image figure {
  flex: 1 1 auto;
  width: 100%;
  max-width: 350px;
}
@media print, screen and (min-width: 768px) {
  #news .news_detail .news-image figure {
    /*TB*/
    max-width: 600px;
  }
}
#news .news_detail .news-image figure img {
  aspect-ratio: 4/3;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#news .news_detail a {
  display: block;
}

#contact .inner:has(.contact-tel) {
  margin-bottom: 5rem;
}
@media print, screen and (min-width: 1280px) {
  #contact .inner:has(.contact-tel) {
    /*TB*/
    margin-bottom: 10rem;
  }
}
#contact .contact-tel {
  text-align: center;
}
#contact .contact-tel p.p_tel {
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
  margin-top: 1em;
}
#contact .contact-tel p.p_tel a {
  font-size: 2em;
}

/* ----------------------- form ----------------------- */
#form {
  max-width: 760px;
  margin: 5rem auto;
}
@media print, screen and (min-width: 1280px) {
  #form {
    /*TB*/
    margin-top: 10rem;
  }
}
#form .contact-flow {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  counter-reset: flow 0;
  margin-bottom: 4em;
}
#form .contact-flow li {
  position: relative;
  display: inline-block;
  counter-increment: flow 1;
  line-height: 1;
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
}
#form .contact-flow li span {
  display: inline-block;
  padding: 0.5em 0;
}
#form .contact-flow li.current span {
  border-bottom: solid 0.2rem #070707;
}
#form .contact-flow li::after {
  content: "→";
  display: inline-block;
  margin: 0 0.3em;
}
@media print, screen and (min-width: 1280px) {
  #form .contact-flow li::after {
    /*TB*/
    margin: 0 1em;
  }
}
#form .contact-flow li:last-child::after {
  content: none;
}
#form dl {
  display: flex;
  flex-flow: row wrap;
}
#form dl dt,
#form dl dd {
  width: 100%;
  margin-bottom: 2rem;
}
#form dl dt {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: flex-start;
  padding: 1em 0;
}
@media print, screen and (min-width: 1280px) {
  #form dl dt {
    /*TB*/
    width: 30%;
  }
}
#form dl dt .required {
  display: inline-block;
  font-size: 0.8em;
  color: #d80f0f;
  padding: 0.5rem 1rem;
  margin-left: auto;
  line-height: 1;
  vertical-align: middle;
}
#form dl dt .required::before {
  content: "（";
}
#form dl dt .required::after {
  content: "）";
}
#form dl dd {
  line-height: 1;
  background-color: #f1f3f1;
}
@media print, screen and (min-width: 1280px) {
  #form dl dd {
    /*TB*/
    width: 70%;
  }
}
#form dl dd label {
  position: relative;
  display: inline-block;
  padding: 1em 0 1em 1em;
}
#form dl dd label:not(:last-of-type) {
  margin-right: 3em;
}
#form dl dd label::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  border: solid 0.3rem #f1f3f1;
  vertical-align: middle;
  vertical-align: sub;
  margin-right: 0.5em;
  outline: solid 0.1rem #070707;
}
@media print, screen and (min-width: 1280px) {
  #form dl dd label::before {
    /*TB*/
    border: solid 0.4rem #f1f3f1;
  }
}
#form dl dd label:has(input[type=radio])::before {
  border-radius: 50%;
}
#form dl dd label:has(input[type=radio]):has(:checked)::before {
  background-color: #070707;
}
#form dl dd label:has(input[type=checkbox])::after {
  position: absolute;
  content: "";
  display: block;
  left: 1.15em;
  top: 1.3em;
  width: 0.7em;
  height: 0.5em;
  border-left: solid 0.2rem #070707;
  border-bottom: solid 0.2rem #070707;
  transform: rotate(-45deg);
  opacity: 0;
}
@media print, screen and (min-width: 1280px) {
  #form dl dd label:has(input[type=checkbox])::after {
    /*TB*/
    top: 1.25em;
    height: 0.45em;
  }
}
#form dl dd label:has(input[type=checkbox]):has(:checked)::after {
  opacity: 1;
}
#form dl dd label input {
  display: none;
}
#form input,
#form textarea,
#form dd p {
  display: block;
  padding: 1em;
  background-color: transparent;
  width: 100%;
  letter-spacing: 0.1rem;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "MS PMincho", serif;
  color: #070707;
}
#form input:focus, #form input:visited,
#form textarea:focus,
#form textarea:visited,
#form dd p:focus,
#form dd p:visited {
  outline: none;
}
#form textarea {
  max-width: 100%;
  min-width: 100%;
  height: 10em;
  line-height: 1.8;
}
#form .submit_area {
  text-align: center;
  padding: 2rem 0;
}
#form .submit_area a {
  color: #d80f0f;
  text-decoration: underline;
  display: inline-block;
  margin-right: 0.5em;
}
#form .submit_area a::after {
  display: inline-block;
  content: "";
  width: 1em;
  height: 1em;
  background-image: url(../img/icon_window.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  margin-left: 0.5em;
}
#form .submit_area .required {
  color: #d80f0f;
  display: inline-block;
  font-size: 0.8em;
}
#form .submit_area label {
  position: relative;
  display: block;
  width: max-content;
  margin: 0 auto;
}
#form .submit_area label input {
  display: none;
}
#form .submit_area label::before {
  content: "";
  display: inline-block;
  width: 1.8rem;
  height: 1.8rem;
  border: solid 0.1rem #070707;
  vertical-align: middle;
  margin-right: 1rem;
  border-radius: 0.3rem;
  background-color: #FFF;
}
#form .submit_area label::after {
  position: absolute;
  content: "";
  display: block;
  left: 0.25rem;
  top: 0.45rem;
  width: 1.2rem;
  height: 0.7rem;
  border-left: solid 0.2rem #070707;
  border-bottom: solid 0.2rem #070707;
  transform: rotate(-45deg);
  opacity: 0;
}
@media print, screen and (min-width: 1280px) {
  #form .submit_area label::after {
    /*TB*/
    width: 1.4rem;
    height: 0.8rem;
    top: 0.6rem;
    left: 0.2rem;
  }
}
#form .submit_area label:has(:checked)::after {
  opacity: 1;
}
#form .submit_area label:has(:checked) + button {
  cursor: pointer;
  opacity: 1;
  pointer-events: auto;
  background-color: #FFF;
}
#form .submit_area label:has(:checked) + button:hover {
  background-color: #0c1e04;
  color: #FFF;
}
#form button {
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "MS PMincho", serif;
  width: 80%;
  max-width: 280px;
  margin: 2em auto;
  background: #f1f3f1;
  border: solid 0.1rem #0c1e04;
  color: #0c1e04;
  transition: 0.3s;
  padding: 0.8em;
  opacity: 0.6;
  pointer-events: none;
}

.privacy-contents h3 {
  text-align: left;
  margin-top: 4rem;
}
.privacy-contents .address {
  margin-top: 2rem;
  padding: 2rem;
  border: solid 0.1rem #070707;
  display: inline-block;
}
.privacy-contents .address strong {
  font-size: 1.1em;
  font-weight: bold;
}
.privacy-contents .address a {
  display: block;
  margin-top: 1rem;
  padding: 0.5rem 2rem;
  background-color: #85e0d0;
  border-radius: 5rem;
  text-align: center;
  color: #FFF;
}

.end-message {
  text-align: center;
}
.end-message p:nth-of-type(1) {
  display: inline-block;
  text-align: left;
  margin-bottom: 4rem;
}

#partner .gap {
  gap: 5rem;
}
#partner .recruit-message {
  max-width: 740px;
  margin: 0 auto;
}
#partner .recruit-message p {
  margin-top: 1em;
  font-size: clamp(1.6rem, 1.4342541436rem + 0.4419889503vw, 2rem);
}
#partner .recruit-message p:first-of-type {
  margin-top: 0;
}
#partner .recruit-message div {
  background-color: #f1f3f1;
  padding: 2em;
  margin: 4rem 0;
}
#partner .recruit-message div h3 {
  margin-bottom: 1em;
}
#partner .recruit-message div ul {
  line-height: 2;
  margin-bottom: 1em;
}
#partner .recruit-message div ul li {
  margin-top: 1em;
  font-size: clamp(1.5rem, 1.3756906077rem + 0.3314917127vw, 1.8rem);
}
#partner .recruit-message div ul li:first-child {
  margin-top: 0;
}

#error h2,
#privacy h2 {
  font-size: clamp(2.4rem, 1.9027624309rem + 1.3259668508vw, 3.6rem);
  line-height: 1.5;
  margin-bottom: 1.5em;
}
#error h3,
#privacy h3 {
  margin: 2em 0 1em;
}
#error .contact-box,
#privacy .contact-box {
  margin-top: 4rem;
  display: block;
  width: max-content;
  max-width: 100%;
  padding: 2em 1em;
  background-color: #f1f3f1;
}
@media print, screen and (min-width: 1280px) {
  #error .contact-box,
  #privacy .contact-box {
    /*TB*/
    margin-top: 8rem;
  }
}
#error .contact-box h4,
#privacy .contact-box h4 {
  font-size: clamp(1.8rem, 1.6342541436rem + 0.4419889503vw, 2.2rem);
  margin-bottom: 1em;
}
#error .contact-box p,
#privacy .contact-box p {
  margin-top: 1em;
}
#error .contact-box .link_area,
#privacy .contact-box .link_area {
  margin: 2rem 0;
  padding: 0;
}/*# sourceMappingURL=style.css.map */