@import url(../css/global.css);
@import url(../css/header.css);
@import url(../css/footer.css);

.inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* lower mv start */
.lower-mv {
  height: 450px;
  background: url(../img/top-banner-img.jpg) no-repeat;
  background-size: cover;
  z-index: 1;
  padding-top: 100px;
}

.lower-mv__textbox {
  display: flex;
  justify-content: center;
  width: 100%;
}

.lower-mv__text {
  color: white;
  font-weight: 700;
  font-style: normal;
  font-size: 30px;
  letter-spacing: 0.3rem;
  text-shadow: 0px 0px 5px #000000, 0px 0px 10px #000000;
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: center;
  align-items: center;
  line-height: var(--mid-line-height);
  text-transform: uppercase;
  row-gap: 10px;
  text-align: center;
  font-family: var(--font-family-2);
  text-transform: capitalize;
}

.lower-mv__text .jp {
  font-size: 54px;
  line-height: 1.2;
  text-align: center;
}
/* lower mv end */

/* breadcrumb start */
.breadcrumb {
  padding: 30px 3% 0;
  font-size: 18px;
}

.breadcrumb .inner {
  max-width: 1400px;
  margin: auto;
}

ul.breadcrumb__list.flex {
  display: flex;
  flex-direction: row;
  padding-bottom: 0;
}

.breadcrumb li {
  color: #000;
  font-family: var(--font-family-1);
  font-weight: 700;
}

a.home.hv {
  text-decoration: none;
  color: #000;
}

a.home.hv:after {
  content: ">";
  padding-right: 10px;
  padding-left: 10px;
}
/* breadcrumb end */

/* contact banner start */
.contactbnr {
  background: #000;
}

.contactbnr__wrapper {
  display: flex;
  align-items: center;
}

.contactbnr__item {
  width: 50%;
  min-height: 90px;
  padding: 20px 0;
}

.contactbnr__tel {
  border-right: 1px solid #fff;
}

.contactbnr__mail img {
  display: block;
  width: 32px;
  height: auto;
  margin: 0 auto;
}

.contactbnr__link {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.contactbnr__desc {
  color: #fff;
  text-align: center;
}

.contactbnr__desc--large {
  font-size: 30px;
}
/* contact banner end */

/* company page start */
.sub-company .lower-section .inner {
  max-width: 1000px;
  margin: 0 auto;
}

.sub-company__management {
  margin-bottom: 60px;
}
/* company page end */

/* company 2 start */

.sub-company02 .lower-section .inner {
  max-width: 1000px;
  margin: 0 auto;
}

.sub-company02__message .message {
  display: flex;
  gap: 20px;
}

.sub-company02__message .message__imgbox {
  width: 25%;
}

.sub-company02__message .message__imgbox img {
  width: 100%;
}

.sub-company02__message .message__textbox {
  width: 75%;
}

.sub-company02__message .message__name {
  text-align: center;
  padding: 8px;
}

.sub-company02__message .message__name .jp {
  font-size: 20px;
}

.sub-company02__history.container-margin-tb {
  background-color: #d4eaff;
  padding-top: 60px;
  padding-bottom: 60px;
  margin-bottom: 0;
}

.sub-company02__table dl {
  display: flex;
  gap: 20px;
  padding: 30px 20px;
  border-bottom: 1px solid #000;
}

.sub-company02__table dl:first-child {
  border-top: 1px solid #000;
}

.sub-company02__table .col-1 {
  width: 40%;
  max-width: 300px;
  font-size: 18px;
}

.sub-company02__table .col-2 {
  width: 70%;
  min-width: 420px;
}

.sub-company02__table .shareholder .col-2 span,
.sub-company02__table .institution .col-2 span {
  display: inline-block;
  width: 100%;
  max-width: 250px;
}

.sub-company02__table .trading-partners .col-2 .list {
  padding-left: 30px;
}

.sub-company02__table .trading-partners .col-2 .offices {
  margin-bottom: 30px;
}
/* company 2 end */

/* contact page start */

/* sub-contact start */

.sub-contact {
  font-family: var(--font-family-1);
}

.sub-contact a {
  color: #000;
  display: inline-block;
}

.contact-form__item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: var(--half-padding);
}

.contact-form__item--content {
  align-items: flex-start;
}

.contact-form__item--type dd {
  display: flex;
  gap: 8px;
}

.contact-form__item--type dd label {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 50%;
}

.contact-form__item--type dd label input {
  width: 20px;
  height: 20px;
}

.contact-form__item dt {
  display: flex;
  align-content: center;
  align-items: center;
}

.contact-form__item input,
.contact-form__item textarea {
  border: 1px solid #000;
  border-radius: 0;
  padding: 10px;
  width: 100%;
  height: 100%;
  font-family: inherit;
}

.contact-form__item textarea {
  height: 200px!important;
  width: 100%!important;
}

.contact-form__desc {
  text-align: center;
  margin-bottom: 40px;
}

.contact-form__check,
.contact-form__submit {
  display: flex;
  justify-content: center;
  margin-top: var(--half-padding);
}

.contact-form__check {
  margin-bottom: 50px;
}

.contact-form__check label input {
  vertical-align: baseline;
  margin: 0 2px;
}

.sub-contact .btn01 {
  border-radius: 100vw;
  background-color: #634111;
  color: #fff;
  font-family: var(--font-family-1);
}

.sub-contact .contact-form__policy {
  background-color: #ececec;
  padding: 20px;
  height: 200px;
  overflow-y: scroll;
  margin-bottom: 60px;
  border: 1px solid #000;
  font-family: var(--font-family-1);
}

.contact-form__policy::-webkit-scrollbar {
  width: 20px;
}

.contact-form__policy::-webkit-scrollbar-track {
  background-color: #fff;
  border-left: 1px solid #000;
}

.contact-form__policy::-webkit-scrollbar-thumb {
  background-color: #000;
}
/* contact page end */

/* privacy start */

.lower-privacy .inner {
  max-width: 1000px;
  margin: 0 auto;
}

.lower-privacy span {
  display: block;
}
/* privacy end */

/* top interview start*/

.top-section .wrapper {
  display: flex;
}

.top-section__imgbox {
  width: 55%;
  padding-top: 6.2vw;
}

.top-section__textbox {
  background: url(../img/brown-bg.png) no-repeat;
  background-position: top right;
  background-size: cover;
  width: 45%;
  padding: 5vw 3% 30px 30px;
  max-height: 28vw;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.top-interview .btn a {
  background-image: linear-gradient(to right, #452b0a, #503106);
}
/* top interview end */

/* business start */

.top-business .inner {
  background: url(../img/brown-solid-line.png);
  background-repeat: no-repeat;
  background-size: 45% auto;
  background-position: left top 60%;
}

.top-business .section__ttl {
  margin-left: 15%;
  position: relative;
  z-index: 3;
}

.top-business .wrapper {
  display: flex;
}

.top-business .wrapper.reverse {
  flex-direction: row-reverse;
}

.top-business__heating {
  background: url(../img/red-brown-bg.png);
  background-repeat: no-repeat;
  background-size: 100% auto;
  background-position: left top;
  padding-top: 30px;
  margin-top: -140px;
}

.top-business__construction {
  background: url(../img/red-solid-line.png);
  background-repeat: no-repeat;
  background-size: 70% auto;
  background-position: right bottom 40px;
}

.top-business__heating .top-business__imgbox {
  width: 45%;
  position: relative;
  top: 30px;
}

.top-business__construction .top-business__imgbox {
  width: 50%;
}

.top-business__heating .top-business__textbox {
  width: 50%;
  margin-right: auto;
  padding: 0 0 0 15%;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 140px;
  position: relative;
  top: 140px;
}

.top-business__construction .top-business__textbox {
  width: 50%;
  padding: 0 15% 30px 0;
  position: relative;
  top: -30px;
  left: -30px;
}

.top-business__heating .top-business__item {
  background: #090909;
  padding: 30px;
}

.top-business__construction .top-business__item {
  background: #664414;
  padding: 30px;
}

.top-business .wrapper .top-business__item .content {
  max-width: 370px;
}

.top-business .wrapper .top-business__item .ttl {
  border-bottom: 1px solid #fff;
  padding-bottom: 16px;
  font-size: 20px;
}

.top-business .wrapper .top-business__item .list {
  padding-left: 20px;
}

.top-business .wrapper .top-business__item .list .item {
  margin-bottom: 8px;
}

.top-business .wrapper .top-business__item .list .item::marker {
  content: "■";
  font-size: 16px;
}

.top-business .btn a {
  margin-top: -80px;
  background-color: #2c2c2c;
  position: relative;
  z-index: 2;
}
/* business end */

/* about start */

.top-about .inner {
  background: url(../img/top-about-2.png) no-repeat;
  background-size: 100% auto;
  background-position: left top;
  padding-top: 230px;
}

.top-about .wrapper {
  flex-direction: row-reverse;
}

.top-about__textbox {
  width: 45%;
  background: url(../img/top-about-3.png) no-repeat;
  background-size: cover;
  height: 660px;
  max-height: unset;
  padding-left: 15%;
  display: flex;
  padding: 6vw 3% 30px 15%;
  flex-direction: column;
  justify-content: center;
}

.top-about__textbox .section__ttl {
  color: #664414;
}

.top-about .list {
  padding-left: 20px;
  color: #000;
}

.top-about .list .item::marker {
  content: "■";
  font-size: 16px;
}

.top-about__imgbox {
  width: 55%;
  padding-top: 0;
  margin-top: -95px;
}

.top-about .btn a {
  background-image: linear-gradient(to right, #630005, #c4000a);
}
/* about end */

/* history start */
.top-history {
  margin-top: -100px;
}

.top-history__textbox {
  background: url(../img/fade-red-bg.png) no-repeat;
  background-position: top right;
  background-size: auto 100%;
}

.top-history .btn a {
  background-image: linear-gradient(to right, #6d5327, #ad7d39);
}
/* office start */

.top-office {
  margin-top: -50px;
}

.top-office .wrapper {
  flex-direction: row-reverse;
}

.top-office__imgbox {
  padding-top: 0;
}

.top-office__textbox {
  background: unset;
  width: 45%;
  padding: 140px 3% 30px 15%;
}
/* office end */

/* recruit start */

.top-recruit {
  margin-top: -50px;
  margin-bottom: 50px;
}

.top-recruit .inner {
  background: url(../img/brown-red.png) no-repeat;
  background-size: 100% auto;
  background-position: left top;
  padding-top: 40px;
}

.top-recruit__textbox {
  background: none;
  width: 45%;
  padding: unset;
  max-height: unset;
  position: relative;
}

.top-recruit__content {
  background: url(../img/brown-bg.png) no-repeat;
  background-position: top right;
  background-size: auto 100%;
  padding: 8vw 3% 30px 30px;
  min-height: 35vw;
  position: absolute;
  top: 130px;
  right: 0;
  width: 123%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.top-recruit .btn a {
  background-image: linear-gradient(to right, #630005, #c4000a);
}
/* recruit end */

/* csr start */
.top-csr .wrapper {
  flex-direction: row-reverse;
}

.top-csr__imgbox {
  padding-top: 0;
}

.top-csr__textbox {
  background: unset;
  padding-left: 15%;
}
/* csr end */

/* sub-news start */

.lower-section .inner.bb {
  border-bottom: 1px solid #000;
  padding-bottom: 50px;
  max-width: 1400px;
}

.sub-news .card {
  max-width: 1200px;
  margin: auto;
  margin-bottom: 25px;
}

.sub-news .card a {
  color: #000;
  width: 100%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.sub-news .card a .date {
  width: 30%;
}

.sub-news .card a .title {
  width: 70%;
  display: flex;
  justify-content: space-between;
  gap: 20px;
}

.news__pagination li a {
  color: #000;
  border: 1px solid #bdbdbdbb;
  padding: 5px 10px;
}

.news__pagination {
  display: flex;
  justify-content: right;
  gap: 10px;
  padding-top: 30px;
}

.news__pagination .next-page,
.news__pagination .prev-page {
  background-color: #ad7d39;
  color: #fff;
  border: 1px solid #000;
}

.sub-news .news__pagination a:where([aria-current]) {
  color: #ad7d39;
}

.sub-news .content-wrap {
  max-width: 1200px;
  margin: auto;
}

.sub-news .news-detail__ttl {
  display: flex;
  flex-direction: column;
  color: #000;
  row-gap: 15px;
}

.sub-news .thanks {
  color: #000;
}

.sub-news .wrap {
  max-width: 800px;
  margin: auto;
  margin-bottom: 30px;
}

.sub-news .wrap img {
  width: 100%;
  object-fit: cover;
}

/* sub-news-mv-text */

#news .mv-text-small .lower-mv__text {
  row-gap: 10px;
}

#news .mv-text-small .lower-mv__text .jp {
  font-size: 34px;
}

/* sub-news-mv-end */

/* .sub-news .lower-section {
  border: none;
}

.sub-news .lower-section .cards {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

.sub-news .lower-section .cards .card {
  width: calc(calc(100% / 3) - calc(30px * calc(2 / 3)));
}

.sub-news .lower-section .cards .card a .image img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.sub-news .lower-section .cards .card a .image {
  margin-bottom: 20px;
}

.sub-news .lower-section .cards .card a .ttl {
  display: flex;
  flex-direction: column;
  font-weight: 700;
}

.sub-news .lower-section .cards .card a span {
  font-weight: 500;
  width: fit-content;
  padding: 4px 8px;
  background-color: var(--main-bg-color);
  color: #fff;
  margin-bottom: 16px;
}

.sub-news .lower-news-details .news-detail__image {
  width: 100%;
  margin-bottom: 30px;
}

.sub-news .lower-news-details .news-detail__image img {
  width: 100%;
  height: 100%;
}

.sub-news .lower-news-details .news-detail__date {
  font-weight: 700;
  margin-bottom: 16px;
  font-size: 20px;
}

.sub-news .lower-news-details .news-detail__date span {
  color: #fff;
  padding: 4px;
  background-color: var(--main-bg-color);
  margin-left: 20px;
  text-align: center;
}

.sub-news .lower-news-details .news-detail__ttl {
  font-size: 22px;
  margin-bottom: 16px;
}

.sub-news .lower-news-details .text-wrapper {
  width: 100%;
  font-weight: 700;
}

.sub-news .news__pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 30px;
}

.sub-news .news__pagination a:where([aria-current]) {
  font-weight: 700;
  color: var(--main-bg-color);
}

.sub-news--content .news-detail__postlink {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30px;
  margin-top: 100px;
}

.sub-news--content .news-detail__postlink .back a {
  background-color: var(--main-bg-color);
  color: #fff;
  padding: 12px;
}

.sub-news--content .news-detail__postlink li a {
  font-weight: 700;
  font-size: 18px;
} */
/* sub-news end */

/*jun start*/
#anniv-company main a {
  color: #000;
}

.anniv-company_lower .section__ttl {
  color: #000;
  font-family: var(--font-family-1);
}

.sub_anniv-company,
.sub-works,
.sub_company-profile {
  background: #fff;
  color: #000;
  font-family: var(--font-family-2);
}

.sub_anniv-company,
.sub-works,
.sub_company-profile p {
  color: #000;
  font-weight: 100;
}

.dialogue_top img {
  width: 100%;
}

.dialogue_card {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}

.dialogue_card .card {
  width: calc(calc(100% / 3) - calc(20px * calc(3 / 4)));
}

.dialogue_card .card--1 {
  width: 100%;
}

.dialogue_card .card img {
  width: 100%;
}

.dialogue__img img {
  width: 100%;
}

.dialogue__txtwrap {
  padding: 30px 0;
}

.dialogue__txt h3 {
  font-size: 25px;
  margin-bottom: 20px;
  font-family: var(--font-family-1);
}

.dialogue__txt p {
  font-weight: 100;
}

.dialogue .brown-bgtxt {
  background-color: #503106;
  color: #fff;
  display: flex;
  padding: 15px;
  justify-content: space-evenly;
  font-size: 20px;
}

.construction-result_wrap .bb {
  border-bottom: solid 1px;
}

.construction-result_ttl {
  background-color: #8f5f1a;
  color: #fff;
  text-align: center;
  padding: 10px 10px;
  font-size: 25px;
  margin-bottom: 20px;
}

.construction-result_list {
  padding-bottom: 60px;
}

.construction-result_list li {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  flex-wrap: wrap;
}

.construction-result_list li span {
  width: calc(calc(100% / 4) - calc(0px * calc(3 / 4)));
  color: #8f5f1a;
  font-weight: 100;
}

.construction-result_list li span:nth-child(2),
.construction-result_list li span:nth-child(3),
.construction-result_list li span:nth-child(4) {
  padding-left: 100px;
}

.sub-works {
  font-family: var(--font-family-2);
}

.sub-works .table__ttl {
    background-color: #8f5f1a;
    padding: 12px;
    color: #fff;
    font-size: 24px;
    text-align: center;
    font-weight: 500;
    font-family: var(--font-family-1);
}

.sub-works__table {
  width: 100%;
  padding: 30px 30px 0;
  color: #8f5f1a;
  /*font-weight: bold;*/
}

.sub-works__table .row {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}

.sub-works__table .row .col {
  padding: 10px 0;
  width: 25%;
}

.sub-works__table .row .col:first-child {
  width: 40%;
}

.sub-works__table .row .col:last-child {
  width: 10%;
}

.sub-works__table .table__space {
  color: transparent;
  visibility: hidden;
}

.company__ttl {
  background: url(../img/company-bg01.png) no-repeat;
  background-position: center;
  background-size: cover;
}

.company__ttl .inner {
  display: flex;
  justify-content: center;
  align-items: center;
}

.company__ttl .left img {
  width: 85%;
}

.company__ttl .left {
  width: 48%;
  padding-left: 20px;
}

.company__ttl .right {
  width: 48%;
  padding-left: 20px;
}

.company__ttl h1 {
  font-size: 6.5vh;
  margin-bottom: 10px;
  letter-spacing: 10px;
}

.company__ttl h2 {
  font-size: 20px;
  margin-bottom: 30px;
  letter-spacing: 5px;
}

.company__ttl .right .ttl {
  font-size: 30px;
}

.company__ttl .pc {
  display: block;
}

.company__ttl .sp {
  display: none;
}

.company__graph {
  display: flex;
  justify-content: space-between;
  /* margin-bottom: 60px; */
  align-items: stretch;
}

.company__graph .graph {
  color: #9c7a52;
  font-weight: 600;
}

.company__graph .graph h2 {
  font-size: 50px;
  font-family: var(--font-family-1);
}

.company__graph .graph img {
  width: 100%;
}

.company__graph .small-txt {
  font-size: 16px;
  font-family: var(--font-family-1);
}

.company__graph .scnd_small-txt {
  font-size: 30px;
  padding-left: 10px;
}

.company__lower .message .message__wrap {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.company__lower .message .section__ttl {
  color: #9f7a46;
  text-align: center;
  font-family: var(--font-family-2);
}

.message {
  margin-bottom: 60px;
}

.message__wrap .policy {
  display: flex;
  flex-direction: column;
  font-weight: 100;
  gap: 10px;
}

.message__wrap .policy .brown-tx {
  color: #9f7a46;
  font-size: 25px;
  font-family: var(--font-family-1);
  font-weight: bold;
}

.message__wrap .policy .brown-bg {
  color: #fff;
  background-color: #9f7a46;
  padding: 10px 10px;
  font-family: var(--font-family-1);
}

.message__wrap .left img {
  width: 100%;
}

.message__wrap .left,
.right {
  width: 47%;
}

.message__wrap .right h3 {
  font-size: 22px;
  font-family: var(--font-family-1);
}

.message__wrap .right p {
/*  font-family: var(--font-family-1);*/
  font-size: 18px;
  /*line-height: 19px;*/
  font-family: var(--font-family-1);
  font-weight: 500;
}

.message__wrap .left h2 {
  font-size: 25px;
  text-align: center;
  padding: 10px;
 /* font-family: var(--font-family-1);*/
}

.message__wrap .left .small-tx {
  font-size: 16px;
}

.company__profile .section__ttl {
  color: #000;
  font-size: 25px;
  font-family: var(--font-family-2);
}

.company__profile {
  background: url(../img/company-bg02.png) no-repeat;
  background-position: center;
  background-size: cover;
  padding: 60px 3%;
}

.company__profile .content {
  display: flex;
  justify-content: space-evenly;
}

.company__profile-wrap ul li {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-family-1);
  font-weight: 500;
}

.company__profile-wrap ul li .label {
  width: 20%;
  padding: 10px 0;
  /*border-bottom: solid 1px;*/
}

.company__profile-wrap ul li .details {
  width: 78%;
  padding: 10px 0;
  border-bottom: solid 1px;
  display: flex;
  align-items: center;
  font-family: var(--font-family-2);
  font-weight: bold;
}

.company__profile .left {
  width: 61%;
}

.company__profile .right {
  width: 34%;
  gap: 15px;
}

.company__profile .right img {
  width: 100%;
  margin-bottom: 40px;
}

/*jun end*/

/* sub-history start */

#history .lower-page {
  position: relative;
  z-index: 0;
}

.mid-line {
  display: block;
  width: 10px;
  height: 100%;
  background-color: #bdbdbd73;
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  z-index: -1;
}

.corporate-history {
  background-color: #fff;
  color: #000;
}

.sub-history .sub-history--content {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.sub-history--content .item {
  width: 50%;
  display: flex;
  align-items: center;
}

.sub-history--content .item .cards {
  border: 5px solid #bdbdbdbb;
  width: 65%;
  padding: 10px;
  position: relative;
}

.sub-history--content .item .cards .year {
  font-size: 28px;
  color: #664414;
}

.sub-history--content .item .cards img {
  width: 100%;
  object-fit: cover;
}

.sub-history--content .item .line {
  display: block;
  width: 35%;
  height: 2px;
  border: 1px solid #000;
  position: relative;
  display: flex;
}

.sub-history--content .item .line:before {
  content: "";
  position: absolute;
  right: 0;
  top: -8px;
  width: 15px;
  height: 15px;
  border-radius: 50vw;
  background-color: #000;
}

.sub-history--content .item:nth-of-type(even) .line:before {
  right: initial;
  left: 0;
}

.sub-history--content .item:nth-of-type(even) {
  position: relative;
  left: -7px;
  margin-top: 150px;
}

.sub-history--content .item:nth-of-type(odd) {
  right: -7px;
  position: relative;
  margin-bottom: 200px;
}

.sub-history--content .item:nth-of-type(13) {
  margin-bottom: 0;
}

.sub-history--content .item .line::after {
  content: "1994";
  position: absolute;
  right: -10%;
  top: -70px;
  transform: translateX(10%);
  font-size: 40px;
  font-weight: bold;
  color: #664414;
}

.sub-history--content .item:nth-of-type(even) .line::after {
  right: initial;
  left: -17%;
  transform: translateX(-17%);
}

.sub-history--content .item .line.line02::after {
  content: "1995";
}
.sub-history--content .item .line.line03::after {
  content: "2007";
}
.sub-history--content .item .line.line04::after {
  content: "2010";
}
.sub-history--content .item .line.line05::after {
  content: "2011";
}
.sub-history--content .item .line.line06::after {
  content: "2013";
}
.sub-history--content .item .line.line07::after {
  content: "2014";
}
.sub-history--content .item .line.line08::after {
  content: "2015";
}
.sub-history--content .item .line.line09::after {
  content: "2016";
}
.sub-history--content .item .line.line10::after {
  content: "2017";
}
.sub-history--content .item .line.line11::after {
  content: "2019";
}
.sub-history--content .item .line.line12::after {
  content: "2023";
}

.sub-history--content .item .line.line13::after {
  content: "2024";
}

.invisible {
  opacity: 0;
  appearance: none;
  width: 0;
}

/* ado-2023-card */

.sub-history--content .item:nth-of-type(12) p,
.sub-history--content .item:nth-of-type(12) .cards .year {
  color: #fff;
}

.sub-history--content .item:nth-of-type(12) .cards {
  background-color: #8f5f1a;
  border: none;
}

.sub-history--content .item .cards .ado-wrap {
  position: relative;
  margin-bottom: 15px;
}

.sub-history--content .item .cards .ado-wrap .float {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 60%;
  transform: translateX(-50%) translateY(-50%);
  z-index: 4;
}

.sub-history--content .item .cards .float2 {
  position: absolute;
  right: 5%;
  top: 5%;
  width: 120px;
  z-index: 5;
}

.sub-history--content .item:nth-of-type(12) p {
  margin-bottom: 15px;
}

/* sub-history end */

/* sub-office-start */

.office_info {
  background: #fff;
  /* padding-bottom: 7%; */
}

.map-start {
  position: relative;
}

.map-details {
  color: #000;
  position: absolute;
  left: 0;
  top: 0;
}

.map-details .map_title {
  font-size: 42px;
  margin-bottom: 10px;
}

.map-details .green {
  color: #0dc259;
}

.map-details .legend .green {
  margin-left: -10px;
  margin-right: -10px;
}

.map-details .legend {
  font-size: 22px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 15px;
}

.map-details .legend .box {
  display: block;
  width: 30px;
  aspect-ratio: 1;
  border: 1px solid #000;
}

.map-details .legend .box.green-box {
  background-color: #2cc259;
}

.map-start img {
  width: 87%;
}

.map-start .map-content {
  width: 100%;
}

.office_info .card {
  color: #000;
  max-width: 350px;
  width: 100%;
  position: absolute;
  left: 0%;
  top: 33%;
  transform: translateX(-12%) translateY(-23.5%);
  background-color: #fff;
  z-index: 1;
}

.office_info .card.card02 {
  left: initial;
  transform: none;
  right: -0.75%;
  top: 15.5%;
}

.office_info .card.card03 {
  left: initial;
  transform: none;
  right: 9.75%;
  top: 68%;
}

.map_ttl {
  background-color: #2c2c2c;
  color: #fff;
  padding: 5px 10px;
  font-size: 23px;
  position: relative;
}

.map_txt {
  margin-bottom: 10px;
}

.map-area {
  padding: 15px 3%;
  border: 1px solid #000;
}

.map-area iframe {
  width: 100%;
  max-height: 130px;
}

.map-area::after {
  content: "";
  width: 102%;
  height: 3px;
  background-color: red;
  position: absolute;
  right: -102%;
  top: 30.2%;
  transform: translateY(-50%) rotate(5deg);
}

.office_info .card.card02 .map-area::after {
  right: initial;
  transform: translateY(-30%) rotate(35deg);
  top: 36%;
  left: -44.5%;
  width: 49%;
}

.office_info .card.card03 .map-area::after {
  right: initial;
  transform: translateY(-30%) rotate(68deg);
  top: -19.2%;
  left: -50%;
  width: 73%;
}

/* .office_info {
  background: #fff;
}

.hide-pc {
  display: none;
}

.sub-office .image-area {
  width: 100%;
  position: relative;
}

.sub-office .image-area img {
  width: 100%;
}

.sub-office .map-link-1:hover,
.sub-office .map-link-2:hover,
.sub-office .map-link-3:hover {
  background-color: #2c2c2c3b;
  opacity: 1;
  appearance: unset;
}

.sub-office .map-link-1 {
  display: block;
  width: 28%;
  height: 40%;
  background-color: transparent;
  opacity: 0;
  appearance: none;
  position: absolute;
  left: 16.5%;
  top: 22%;
  transition: 0.5s ease;
}

.sub-office .map-link-2 {
  display: block;
  width: 28%;
  height: 38%;
  background-color: transparent;
  opacity: 0;
  appearance: none;
  position: absolute;
  right: 5.3%;
  top: 11.2%;
}

.sub-office .map-link-3 {
  display: block;
  width: 28%;
  height: 40%;
  background-color: transparent;
  opacity: 0;
  appearance: none;
  position: absolute;
  left: 48.4%;
  top: 58%;
} */

/* sub-office-end */

/* sub-attractive start*/

.sub-attractive {
  font-family: var(--font-family-1);
}

.sub-attractive .section__ttl {
  color: #000;
  font-family: var(--font-family-1);
  margin-bottom: 30px;
}

.sub-attractive .future .wrapper {
  background-color: #f6f8f2;
  padding: 40px;
}

.sub-attractive .future .wrapper-container {
  display: flex;
  gap: 40px;
  margin-bottom: 60px;
}

.sub-attractive .future .wrapper-container.mb0 {
  margin: 0;
}

.sub-attractive .future .wrapper-container .textbox {
  width: 56%;
}

.sub-attractive .future .wrapper-container .textbox .heading {
  background: #fff;
  padding: 40px;
  width: calc(100% + 40px);
  position: relative;
  left: -40px;
  margin-bottom: 30px;
  /* height: 200px; */
}

.sub-attractive .future .wrapper-container .textbox .heading__desc {
  font-size: 20px;
  margin-bottom: 40px;
}

.sub-attractive .future .wrapper-container .textbox .item__q {
  color: #8f5f1a;
}

.sub-attractive .future .wrapper-container .imgbox {
  width: 44%;
}

.sub-attractive .future .wrapper-container .imgbox--full {
  width: 100%;
}

.sub-attractive .future .wrapper-container .imgbox img {
  width: 100%;
}

.sub-attractive .future .wrapper-container--images {
  margin-bottom: 0;
}

.sub-attractive .future .wrapper-container--images > .imgbox {
  width: 50%;
}

.sub-attractive .flow .container {
  padding: 1px 0 30px;
  padding-left: 60px;
  position: relative;
}

.sub-attractive .flow .container::before {
  content: "";
  display: block;
  width: 2px;
  height: 100%;
  background-color: #a8a8a8;
  position: absolute;
  top: 0;
  left: 30px;
}

.sub-attractive .flow .wrapper .ttl {
  margin: 30px 0;
  font-size: 22px;
  color: #8f5f1a;
  position: relative;
  display: flex;
  align-items: center;
  font-family: var(--font-family-1);
}

.sub-attractive .flow .wrapper .ttl::before {
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  background-color: #8f5f1a;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: -29px;
  transform: translate(-50%, -50%);
}

.sub-attractive .flow .content {
  display: flex;
  gap: 20px;
}

.sub-attractive .flow .content .imgbox {
  width: 40%;
}

.sub-attractive .flow .content .imgbox img {
  width: 100%;
}

.sub-attractive .flow .content .textbox {
  width: 60%;
}

.sub-attractive .scenery .ttl {
  font-size: 22px;
}

.sub-attractive .scenery .cards {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30px;
  margin-bottom: 30px;
}

.sub-attractive .scenery .cards .card {
  width: calc(calc(100% / 2) - calc(30px * calc(1 / 2)));
}

.sub-attractive .scenery .cards .card img {
  width: 100%;
}
/* sub-attractive end */

@media (max-width: 1700px) {
  .map-start {
    /* overflow-x: scroll; */
  }
}

/* @media (max-width: 1600px) {
  .top-section__textbox {
    max-height: 460px;
  } */

@media (max-width: 1280px) {
  .map-area::after {
    display: none;
  }

  .office_info .card-area {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    flex-wrap: wrap;
  }

  .office_info .card {
    width: calc(calc(100% / 3) - calc(20px * calc(2 / 3)));
    position: initial;
    left: initial;
    top: initial;
    right: initial;
    transform: none;
  }

  .office_info .card.card01 {
    order: 2;
  }

  .office_info .card.card02 {
    order: 1;
  }

  .office_info .card.card03 {
    order: 3;
  }
}

@media (max-width: 1200px) {
  .sub-works__table {
    padding: 0;
  }

  .sub-works__table .row:not(.table__space) {
    padding: 12px;
    flex-direction: column;
    gap: 4px;
    border-bottom: 1px solid #cecece;
  }

  .sub-works__table br {
    display: none;
  }

  .sub-works__table .row .col,
  .sub-works__table .row .col:first-child,
  .sub-works__table .row .col:last-child {
    width: 100%;
    padding: 0;
  }

  .company__profile .content {
    flex-direction: column;
    padding: 0 10px;
    gap: 30px;
  }

  .company__profile .left {
    width: 100%;
  }

  .company__profile .right {
    width: 100%;
    display: flex;
    justify-content: space-evenly;
  }

  .company__profile .right img {
    margin-bottom: 0;
  }

  .company__logo {
    width: 68%;
  }

  .company__address {
    width: 50%;
  }
}

dd {
    width: 40%;
}


.red_kome{
    color:red;
}












.recruit-box p.read {
    text-align: center;
    font-size: 16px;
    margin: 0 0 49px;
}

.recruit-box .recruit_list li .reclist_box p.ttls {
    line-height: 68px;
    padding: 0 0 0 44px;
    font-size: 20px;
    font-weight: bold;
    color: #FFF;
    margin: 0 0 26px;
    background: #8f5f1a;
}

.recruit-box .recruit_list li .reclist_box {
    /* background: #f1f4f7; */
    padding: 0 0 35px;
    border: 3px solid #8f5f1a5c;
    margin-left: 2%;
    margin-right: 2%;
}

.recruit-box .recruit_list li .reclist_box h3.type05 {
    padding: 0 0 0 44px;
    color: #8f5f1a;
    font-weight: bold;
    font-size: 22px;
    margin: 0 0 18px;
}

.recruit-box .recruit_list li .reclist_box .boxtype1 {
    padding: 22px 44px 27px 44px;
    border-top: 2px solid #d5dee7;
    display: flex;
    justify-content: space-between;
}

.recruit-box .recruit_list li .reclist_box .boxtype1 .lbox p.subttls {
    font-size: 16px;
    text-align: center;
    width: 102px;
    font-weight: bold;
    color: #FFF;
    background: #8f5f1a;
    border-radius: 15px;
}

.recruit-box .recruit_list li .reclist_box .boxtype1 .rbox p.t1 {
    text-align: right;
    font-size: 16px;
}
.recruit-box .recruit_list li .reclist_box .boxtype1 .lbox p.subttls {
    font-size: 16px;
    text-align: center;
    width: 102px;
    font-weight: bold;
    color: #FFF;
    background: #8f5f1a;
    border-radius: 15px;
}

.recruit-box .recruit_list li .reclist_box a.btn03 {
    display: block;
    text-align: center;
    margin: 42px auto 0;
    width: 260px;
    height: 44px;
    display: flex;
    align-items: center;
    font-size: 16px;
    justify-content: center;
    font-weight: bold;
    color: #8f5f1a;
    border: 3px solid #8f5f1a;
    line-height: 1;
}

.recruit-box .recruit_list li {
    margin: 0 0 52px;
}


.recruit-box.container {
    padding: 62px 0 139px;
}





.recruitdetail-box .recdetail p.ttls {
    padding: 0 3%;
}

.recruitdetail-box .recdetail p.ttls {
    line-height: 67px;
    font-size: 20px;
    font-weight: bold;
    font-family: 'Noto Sans Japanese',"ÃƒÂ£Ã†â€™Ã¢â‚¬â„¢ÃƒÂ£Ã†â€™Ã‚Â©ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â®ÃƒÂ£Ã†â€™Ã…Â½ÃƒÂ¨Ã‚Â§Ã¢â‚¬â„¢ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ Pro W3", "Hiragino Kaku Gothic Pro", "ÃƒÂ£Ã†â€™Ã‚Â¡ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¤ÃƒÂ£Ã†â€™Ã‚ÂªÃƒÂ£Ã¢â‚¬Å¡Ã‚Âª", Meiryo,Arial, Osaka, verdana, "ÃƒÂ¯Ã‚Â¼Ã‚Â­ÃƒÂ¯Ã‚Â¼Ã‚Â³ ÃƒÂ¯Ã‚Â¼Ã‚Â°ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â·ÃƒÂ£Ã†â€™Ã†â€™ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¯", "MS PGothic", sans-serif;
    color: #FFF;
    margin: 0 0 22px;
    background: #8f5f1a;
    padding: 0 41px;
}

.recruitdetail-box .recdetail .itembox h3 {
    font-size: 17px;
    font-family: 'Noto Sans Japanese',"ÃƒÂ£Ã†â€™Ã¢â‚¬â„¢ÃƒÂ£Ã†â€™Ã‚Â©ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â®ÃƒÂ£Ã†â€™Ã…Â½ÃƒÂ¨Ã‚Â§Ã¢â‚¬â„¢ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ Pro W3", "Hiragino Kaku Gothic Pro", "ÃƒÂ£Ã†â€™Ã‚Â¡ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¤ÃƒÂ£Ã†â€™Ã‚ÂªÃƒÂ£Ã¢â‚¬Å¡Ã‚Âª", Meiryo,Arial, Osaka, verdana, "ÃƒÂ¯Ã‚Â¼Ã‚Â­ÃƒÂ¯Ã‚Â¼Ã‚Â³ ÃƒÂ¯Ã‚Â¼Ã‚Â°ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â·ÃƒÂ£Ã†â€™Ã†â€™ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¯", "MS PGothic", sans-serif;
    color: #8f5f1a;
    margin: 0 0 12px;
}

.recruitdetail-box .recdetail .itembox p.t1 {
    font-size: 16px;
    color: #434343;
    line-height: 1.8;
}


.recruitdetail-box .recdetail {
    max-width: 870px;
    margin: 0 auto;
    border: 2px solid #baafa0;
    padding: 0 0 63px;
    width: 94%;
}

.recruitdetail-box .recdetail h2 {
    font-size: 32px;
    font-weight: bold;
    font-family: 'Noto Sans Japanese',"ÃƒÂ£Ã†â€™Ã¢â‚¬â„¢ÃƒÂ£Ã†â€™Ã‚Â©ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â®ÃƒÂ£Ã†â€™Ã…Â½ÃƒÂ¨Ã‚Â§Ã¢â‚¬â„¢ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ Pro W3", "Hiragino Kaku Gothic Pro", "ÃƒÂ£Ã†â€™Ã‚Â¡ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¤ÃƒÂ£Ã†â€™Ã‚ÂªÃƒÂ£Ã¢â‚¬Å¡Ã‚Âª", Meiryo,Arial, Osaka, verdana, "ÃƒÂ¯Ã‚Â¼Ã‚Â­ÃƒÂ¯Ã‚Â¼Ã‚Â³ ÃƒÂ¯Ã‚Â¼Ã‚Â°ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â´ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â·ÃƒÂ£Ã†â€™Ã†â€™ÃƒÂ£Ã¢â‚¬Å¡Ã‚Â¯", "MS PGothic", sans-serif;
    margin: 0 0 23px;
    padding: 0 41px;
}

.recruitdetail-box .recdetail .itembox {
    border-top: 2px solid #e0e7ee;
    padding: 15px 15px 15px;
}

.recruitdetail-box .recdetail a.btn03 {
    display: block;
    margin: 47px auto 0;
    text-align: center;
    width: 260px;
    background: #8f5f1a;
    line-height: 44px;
    font-size: 18px;
    font-weight: bold;
    color: #FFF;
}

.recruitdetail-box {
    padding: 63px 0 158px;
}

p.sub-contact__desc.center.mb60 {
    line-height: 35px;
}


@media (max-width: 768px) {
br.pc {
    display: none;
}}

main.sub-contact.fn-d {
    font-family: var(--font-family-1);
}

h2.section__ttl.sub.center {
    letter-spacing: 0;
}



.company__profile-wrap ul li .label {
    width: 20%;
    padding: 10px 0;
    /*border-bottom: solid 1px black;*/
    color: #8f5f1a;
    font-family: var(--font-family-2);
    font-weight: bold;
}

h2.section__ttl.mds {
    letter-spacing: 0;
    border-bottom: 1px solid;
    padding-bottom: 10px;
}


.sub-works__table {
    font-family: var(--font-family-1);
}



@media (min-width: 1000px) {
.company__profile-wrap ul li .label {
     border-bottom: solid 1px black; 
}}


.recruit-box .recruit_list li .reclist_box .boxtype1 .rbox p.t1 {
    text-align: left;
    font-size: 16px;
}


.lbox {
    margin-right: 5%;
}


.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 10;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeOut 1.5s 5.5s forwards;
}

@keyframes fadeOut {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
    visibility: hidden;
  }
}

.loading__logo {
  opacity: 0;
  animation: logo_fade 5.5s 1.5s forwards;
  width: 250px;
}

@keyframes logo_fade {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }

  60% {
    opacity: 1;
    transform: translateY(0);
  }

  100% {
    opacity: 0;
  }
}





.pres img{
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}


@media (max-width: 768px) {
.pres.pc{
	display:none;

}}


@media (min-width: 768px) {
.pres.ssp {
    display: none;
}}



.taidan_midashi {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: var(--quarter-padding);
    padding-top: var(--quarter-padding);
}

p.taidan_txt {
    margin-bottom: var(--quarter-padding);
        font-family: sans-serif;
}


.taidan_flex_outer {
    display: flex;
    flex-direction: row;
    gap: 45px;
    margin-bottom: var(--def-line-height);
    justify-content: space-around;
}

.daihyou img ,.senmu img ,.joumu img{
    width: 28vw;
    max-width: 350px;
    filter: drop-shadow(10px 10px 6px rgba(160, 160, 160, 0.8));
}



h2.taidan_30th {
    text-align: center;
    margin-bottom: var(--def-line-height);
    color: white;
    background: radial-gradient(#8f5f1a 0px, #8f5f1a 25%, #ffffff 60%);
    padding-top: 0.5%;
    padding-bottom: 0.5%;
}


.taidan_left_column {
    padding-left: 47%;
    margin-top: var(--half-padding);
    background-image: url(../img/taidan_img_01.jpg);
    background-size: contain;
    background-repeat: no-repeat;
    margin-top: 5%;
}

.taidan_right_column {
    padding-right: 47%;
    margin-top: var(--half-padding);
    background-image: url(../img/taidan_img_02.jpg);
    background-size: contain;
    background-repeat: no-repeat;
}



.taidan_img_box img {
    width: 100%;
}

.taidan_left_column.second {
    background-image: url(../img/taidan_img_03.jpg);
}

@media (min-width: 1000px) {
.sp_only_img_taidan {
    display: none;
}}


@media (max-width: 1280px) {
.map-start img {
    width: 100%;
}}

h3.taidan_naka_midashi {
    font-size: 24px;
    margin-bottom: var(--quarter-padding);
    /* padding-top: var(--quarter-padding); */
    border-bottom: 1px solid #8f5f1a;
}


.inner.co {
    max-width: 900px;
}

@media (min-width: 769px) {
form#mailformpro dl dd {
    width: 70%!important;
}}

span.w_t_ {
    color: white;
}
