@charset "UTF-8";
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
:root {
  --content_width: 108rem;
  --content-both_space: 20px;
  --header_height: 90px;
}
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  border: 0;
  font-size: 100%;
  font-weight: 400;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

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

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

html {
  -ms-overflow-style: scrollbar;
  font-size: 62.5%;
  overflow: auto;
}

body {
  color: #000000;
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif !important;
  font-size: 16px;
  font-weight: 500;
  height: 100%;
  height: 100%;
  letter-spacing: 0.05em;
  line-height: 1;
  overflow: hidden;
  position: relative;
}
body.is-open::before {
  opacity: 0.95;
  visibility: visible;
}
body::before {
  background-color: #353c46;
  content: "";
  display: block;
  height: 100%;
  left: 0;
  margin: 0 calc(50% - 50vw);
  opacity: 0;
  position: absolute;
  top: 0;
  transition-duration: 0.5s;
  transition-property: opacity, visibility;
  visibility: hidden;
  width: 100vw;
  z-index: -1;
  z-index: 50;
}

[tabindex="-1"]:focus {
  outline: 0 !important;
}

section {
  position: relative;
  width: 100%;
}

hgroup {
  position: relative;
}

a,
button {
  color: inherit;
  display: block;
  height: 100%;
  text-decoration: none;
  transition: 0.5s;
}

picture {
  display: block;
  line-height: 1.2;
}

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

em {
  font-style: normal;
}

svg:not(:root) {
  overflow: hidden;
}

input,
button,
select,
optgroup,
textarea {
  background-color: transparent;
  border: none;
  border: none;
  box-sizing: border-box;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  margin: 0;
  position: relative;
  vertical-align: middle;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -webkit-border-radius: 0;
  -webkit-appearance: none;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

input[type=radio],
input[type=checkbox] {
  box-sizing: border-box;
  padding: 0;
}

input[type=date],
input[type=time],
input[type=datetime-local],
input[type=month] {
  -webkit-appearance: listbox;
}

textarea {
  overflow: auto;
  resize: vertical;
}

fieldset {
  border: 0;
  margin: 0;
  min-width: 0;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  border-offset: -2px;
  -webkit-appearance: none;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
}

output {
  display: inline-block;
}

address {
  font-style: normal;
}
/* スクロールバーのトラックの背景色 */
::-webkit-scrollbar-track {
  background-color: transparent;
}

/* スクロールバーのスクロール部分 */
::-webkit-scrollbar-thumb {
  background-color: #19274e;
  border-radius: 5px;
}

/* スクロールバーの上部ボタン */
::-webkit-scrollbar-button:start {
  display: none;
}

/* スクロールバーの下部ボタン */
::-webkit-scrollbar-button:end {
  display: none;
}

.pc-only-inline {
  display: inline;
}

.sp-only-inline {
  display: none;
}

/* -------------------------------------------*/
/* layout
-------------------------------------------------------*/
/**
 * input
 *
 */
input[type=text],
input[type=date],
input[type=password],
input[type=email],
input[type=time],
input[type=tel],
input[type=number] {
  border: none;
  border: none;
  border: none;
  border-radius: 5px;
  letter-spacing: 0.1em;
  line-height: 1;
  padding: 17px 18px;
  position: relative;
  width: 100%;
}

input[type=number] {
  -moz-appearance: textfield;
}

/**
 * textarea
 *
 */
textarea {
  border: none;
  border: none;
  border-radius: 5px;
  height: 200px;
  letter-spacing: 0.1em;
  padding: 10px;
  position: relative;
  width: 100%;
}

input[type=text]:disabled {
  background: transparent;
  cursor: not-allowed;
}
input[type=text]:disabled::-moz-placeholder {
  color: #039ddc;
  opacity: 1;
}
input[type=text]:disabled::placeholder {
  color: #039ddc;
  opacity: 1;
}

/**
 * radio
 *
 */
input[type=radio] {
  display: none;
  vertical-align: middle;
}

.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0;
}

input[type=radio] + .mwform-radio-field-text {
  cursor: pointer;
  display: inline-block;
  margin: 0 20px 10px 0;
  padding: 10px 10px 10px 40px;
  position: relative;
  transition: 0.5;
  transition-property: color;
  vertical-align: middle;
}

input[type=radio] + .mwform-radio-field-text::before {
  border: 1px solid #7f7f7f;
  border-radius: 50%;
  box-sizing: border-box;
  content: "";
  height: 20px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.5s ease;
  width: 20px;
  z-index: 2;
}

input[type=radio] + .mwform-radio-field-text::after {
  background-color: #0058ea;
  border-radius: 50%;
  box-sizing: border-box;
  content: "";
  display: block;
  height: 12px;
  left: 4px;
  opacity: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  z-index: 5;
}

input[type=radio]:checked + .mwform-radio-field-text::after {
  opacity: 1;
}

/**
 * checkbox
 *
 */
input[type=checkbox] {
  opacity: 0;
  vertical-align: middle;
}

input[type=checkbox] + label {
  cursor: pointer;
  display: inline-block;
  line-height: 1;
  padding: 0 0 0 35px;
  position: relative;
  transition: 0.5;
  transition-property: color;
}

input[type=checkbox] + label::before {
  background: #fff;
  border: 2px #818181 solid;
  box-sizing: border-box;
  content: "";
  height: 16px;
  left: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  z-index: 2;
}

input[type=checkbox] + label::after {
  border-bottom: 3px solid #039ddc;
  border-left: 3px solid #039ddc;
  content: "";
  display: block;
  height: 5px;
  left: 3px;
  opacity: 0;
  position: absolute;
  top: 5px;
  transform: rotate(-45deg);
  transition: 0.5s;
  transition-property: color;
  width: 10px;
  z-index: 3;
}

input[type=checkbox]:checked + label::after {
  opacity: 1;
}

/**
 * tel(column)
 *
 */
.mwform-tel-field {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.mwform-tel-field > input {
  flex: 1;
  width: 100% !important;
}

/**
 * select
 *
 */
.select-parts {
  border: 1px #039ddc solid;
  border-radius: 5px;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.select-parts::after {
  background: url(../img/contact/select_arrow.png) no-repeat top center/contain;
  content: "";
  height: 10px;
  margin-top: 2px;
  pointer-events: none;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  z-index: 5;
}
.select-parts select {
  background: #fbefe3;
  border: none;
  border: none;
  box-shadow: none;
  color: #7f7f7f;
  cursor: pointer;
  font-size: 2rem;
  height: 45px;
  letter-spacing: 0.1em;
  padding: 0 20px 0 15px;
  position: relative;
  text-indent: 0.01px;
  text-overflow: ellipsis;
  width: 100%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  text-align: center;
}

/**
 * file
 *
 */
input[type=file] + label {
  margin: 0 10px 0 0;
  padding: 15px 0;
  width: 160px;
}
input[type=file] + label:after {
  left: 170px;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
.l-footer {
  background-color: #000;
  color: #535f5f;
  width: 100%;
}

.l-footer__inner {
  align-items: flex-start;
  display: grid;
  gap: 6.3461538462%;
  grid-template-columns: 1fr 2.8fr 1.02fr;
  padding-block: 6.8rem 4.8rem;
}

.l-footer__logo img {
  padding-top: 2.2rem;
}

.l-footer__container-menu {
  padding-top: 2.2rem;
}

.l-footer__menu {
  display: flex;
  font-size: 1.4rem;
  line-height: 1;
}

.l-footer__menu-item:last-child > .l-footer__menu-link {
  border-right: 1px dotted #fff;
}

.l-footer__menu-link {
  border-left: 1px dotted #fff;
  padding-block: 0.2rem 1.9rem;
  padding-inline: 1rem;
  position: relative;
}
.l-footer__menu-link::before {
  background-color: #e4ca95;
  bottom: 0.3rem;
  content: "";
  display: block;
  height: 0.5rem;
  left: 1rem;
  position: absolute;
  right: 1rem;
  transition: 0.5s;
  width: 0;
}

.l-footer__menu--sub {
  align-items: end;
  margin-left: auto;
  margin-top: 5.4rem;
  width: -moz-fit-content;
  width: fit-content;
}

.l-footer__menu-item--sub.mr-50 {
  margin-right: 5rem;
}

.l-footer__menu-link--sub {
  border-left: unset;
  padding-block: unset;
  transition: 0.5s;
}
.l-footer__menu-link--sub::before {
  display: none;
}

.l-footer__menu-link--icon {
  aspect-ratio: 1;
  margin-left: 1.5rem;
  transition: 0.5s;
  width: 4.8rem;
}

.l-footer__container-cta {
  font-size: 1rem;
}

.l-footer__cta-p {
  letter-spacing: -0.02em;
  text-align: center;
}

.l-footer__cta-p--2 {
  letter-spacing: -0.02em;
  margin-top: 1.2rem;
}

.l-footer__btn {
  margin-top: 0.6rem;
}

.l-footer__tel a {
  height: 100%;
  margin-top: 1.2rem;
  text-align: center;
}
.l-footer__tel a img {
  height: 100%;
}

.l-footer__cta-access {
  display: block;
  font-size: 1.05rem;
  margin-top: 1.2rem;
  text-align: left;
}

.l-footer__bottom {
  background-color: #1e1e1e;
}

.l-footer__bottom-inner {
  align-items: center;
  display: flex;
  height: 5.4rem;
  justify-content: center;
  padding-top: 1rem;
  position: relative;
}

.l-footer__copyright {
  font-size: 1.15rem;
  letter-spacing: -0.01em;
}

.l-footer__bottom-img {
  aspect-ratio: 207/22.4;
  position: absolute;
  right: 1.5rem;
  top: 65%;
  translate: 0 -50%;
  width: 19.9038461538%;
}

/* -------------------------------------------*/
.header__btn {
  background-color: #9a947e;
  position: fixed;
  right: 2rem;
  top: 1.8rem;
  transition: 0.3s;
  z-index: 200;
}
.header__btn--top.out {
  opacity: 0;
}
.header__btn--top.appear {
  opacity: 1;
}

.header__btn-hamburger {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  padding: 0.8rem;
  pointer-events: none;
}

.header__btn-solid {
  background-color: #fff;
  border-radius: 8px;
  display: block;
  height: 2px;
  transition: 0.5s;
  width: 3.2rem;
}

.header__btn.open .header__btn-hamburger {
  gap: 0.2rem;
  padding: 1.2rem;
}
.header__btn.open .header__btn-hamburger .header__btn-solid--1 {
  transform: translateY(4px) rotate(45deg);
}
.header__btn.open .header__btn-hamburger .header__btn-solid--2 {
  opacity: 0;
}
.header__btn.open .header__btn-hamburger .header__btn-solid--3 {
  transform: translateY(-4px) rotate(-45deg);
}

.header-modal {
  background-color: rgba(154, 148, 126, 0.9);
  display: none;
  height: 100%;
  position: fixed;
  top: 0;
  width: 100%;
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
    z-index: -10;
  }
}
.header-modal.close {
  animation-duration: 200ms;
  animation-fill-mode: forwards;
  animation-name: fadeOut;
  display: block;
  pointer-events: none;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
    z-index: 199;
  }
}
.header-modal.open {
  animation-duration: 200ms;
  animation-fill-mode: forwards;
  animation-name: fadeIn;
  animation-timing-function: ease-out;
  display: block;
}

.header-modal__container {
  padding: 2rem;
}

.header-modal__ul {
  color: #fff;
  margin-top: 8rem;
}
.header-modal__ul li a {
  border-bottom: 1px dashed;
  font-size: 1.5rem;
  margin-bottom: 1em;
  padding-block: 0.8rem;
  padding-left: 0.5em;
}

.hamburger__mv-low-logo {
  margin-left: 1.75%;
  padding-top: 1.2rem;
  width: 22.8rem;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
.l-header {
  container-name: header;
  container-type: inline-size;
  width: 100%;
}
.l-header__mv--low {
  background-image: url(../images/common/mv-low.webp);
  background-position: center 70%;
  background-size: cover;
  container-name: mv-low;
  container-type: inline-size;
  height: 25.8rem;
  position: relative;
  transform: scale(-1, 1);
}
.l-header__mv--low::before {
  background-image: linear-gradient(180deg, rgb(80, 80, 80) 20%, rgb(0, 0, 0));
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  opacity: 0.8;
  position: absolute;
  right: 0;
  top: 0;
}
.l-header__mv-low-logo {
  aspect-ratio: 378/86;
  position: absolute;
  right: 8.75%;
  top: 4rem;
  transform: scale(-1, 1);
  width: 37.8rem;
  z-index: 2;
}
.l-header__mv-low-svg {
  aspect-ratio: 370/55;
  position: absolute;
  right: 39%;
  top: 13rem;
  transform: scale(-1, 1);
  width: 37rem;
}
@container mv-low (max-width: 960px) {
  .l-header__mv-low-svg {
    right: 40%;
    top: 15rem;
    width: 30rem;
  }
}
@container mv-low (max-width: 768px) {
  .l-header__mv-low-svg {
    right: 50.75%;
    top: 7.2rem;
    width: 22.8rem;
  }
}
@container mv-low (max-width: 500px) {
  .l-header__mv-low-svg {
    right: 23.7%;
    top: 7.2rem;
    width: 19.8rem;
  }
}
.l-header__mv-low-decole {
  height: 25.8rem;
  position: absolute;
  right: 0;
  top: 0;
  transform: scale(-1, 1);
  width: 37rem;
}
.l-header__mv-low-decole img {
  -o-object-fit: unset;
  object-fit: unset;
}
@container mv-low (max-width: 960px) {
  .l-header__mv-low-decole {
    right: -7%;
  }
}
@container mv-low (max-width: 768px) {
  .l-header__mv-low-decole {
    height: 100%;
    right: -27px;
    width: auto;
    z-index: -1;
  }
}
.l-header__mv-low-decole-back {
  height: 25.8rem;
  opacity: 0.6;
  position: absolute;
  right: 9.7rem;
  top: 0;
  transform: scale(-1, 1);
  width: 32.4rem;
  z-index: -2;
}
.l-header__mv-low-decole-back img {
  -o-object-fit: unset;
  object-fit: unset;
}
@container mv-low (max-width: 960px) {
  .l-header__mv-low-decole-back {
    right: 2.5%;
    width: 32.4rem;
  }
}
@container mv-low (max-width: 768px) {
  .l-header__mv-low-decole-back {
    height: 100%;
    right: 32px;
    width: auto;
  }
}
.l-header__btn {
  aspect-ratio: 164/49;
  background-color: #535f5f;
  border: 1px solid #535f5f;
  border-radius: 7px;
  margin-top: 0;
  transform: scale(-1, 1);
  width: 16.4rem;
}
.l-header__btn a {
  align-items: center;
  color: #fff;
  display: flex;
  font-size: 1.8rem;
  justify-content: center;
}
.l-header__cta-container {
  bottom: 1.3rem;
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
  left: 7.8rem;
  position: absolute;
}
@container mv-low (max-width: 768px) {
  .l-header__cta-container {
    align-items: end;
    flex-direction: row-reverse;
    left: 1.8rem;
  }
  .l-header .c-cta-btn.l-header__btn {
    font-size: 1.8rem;
  }
  .l-header .c-cta-btn.l-header__btn a {
    width: 16rem;
  }
}
@container mv-low (max-width: 500px) {
  .l-header__cta-container {
    left: 1.8rem;
  }
}
.l-header__inner {
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin-inline: auto;
  margin-top: 0.8rem;
  max-width: var(--content_width);
  padding-inline: 2rem;
}
.l-header__inner--top {
  justify-content: end;
}
.l-header__link-to-top {
  aspect-ratio: 79/12;
  transition: 0.3s;
  width: 7.9rem;
}
.l-header__nav {
  width: calc(594% / var(--content_width) * 100);
}
.l-header__ul {
  color: #535f5f;
  display: flex;
  font-size: 1.8rem;
  line-height: 1;
  margin-left: auto;
}
.l-header__li a {
  border-left: 1px dotted #000;
  font-weight: 600;
  padding-block: 0.7rem 1.4rem;
  padding-inline: 1.1rem;
  position: relative;
}
.l-header__li a::before {
  background-color: #e4ca95;
  bottom: 0;
  content: "";
  display: block;
  height: 0.7rem;
  left: 1rem;
  position: absolute;
  right: 1rem;
  transition: 0.5s;
  width: 0;
}
.l-header__logo {
  display: block;
  width: 15.7rem;
  z-index: 55;
}
.l-header__logo .white {
  display: none;
}
.l-header__trigger {
  align-items: center;
  cursor: pointer;
  display: flex;
  height: 50px;
  justify-content: center;
  padding: 0;
  position: relative;
  width: 60px;
}
.l-header__trigger-inner {
  align-items: center;
  display: flex;
  height: 100%;
  justify-content: center;
  position: relative;
  width: 40px;
}
.l-header__trigger-wrap {
  display: inline-block;
  height: 33.5px;
  position: relative;
  transition: all 0.4s;
  width: 40px;
}
.l-header__trigger-line {
  background-color: #575e67;
  display: inline-block;
  height: 2px;
  left: 0;
  position: absolute;
  transition: 0.5s;
  transition-property: transform;
  width: 40px;
}
.l-header__trigger-line.is-active {
  background-color: #fff;
}
.l-header__trigger-line:nth-of-type(1) {
  top: 0;
}
.l-header__trigger-line:nth-of-type(1).is-active {
  transform: translateY(1rem) rotate(25deg);
}
.l-header__trigger-line:nth-of-type(2).is-active {
  opacity: 0;
}
.l-header__trigger-line:nth-of-type(3) {
  top: 10px;
}
.l-header__trigger-line:nth-of-type(3).is-active {
  transform: translateY(0) rotate(-25deg);
}

/* -------------------------------------------*/
/* -------------------------------------------*/
.l-wrapper {
  position: relative;
  text-align: left;
  width: 100%;
}

.l-main {
  margin-top: 3.4rem;
  position: relative;
  width: 100%;
}
.l-main__inner {
  margin-inline: auto;
  max-width: var(--content_width);
  padding: 0 var(--content-both_space);
  position: relative;
  z-index: 1;
}
.l-main--404, .l-main--error {
  padding-block: 22rem 22.5rem;
}
.l-main--404 h1, .l-main--error h1 {
  margin-inline: auto;
  width: 47rem;
}
.l-main--404 .error-text, .l-main--error .error-text {
  font-size: 1.7rem;
  margin-top: 7.5rem;
  text-align: center;
}
.l-main--404 .error-link, .l-main--error .error-link {
  display: block;
  font-feature-settings: "palt";
  font-size: 1.7rem;
  margin: 7.5rem auto 0;
  padding-bottom: 0.3rem;
  position: relative;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
}
.l-main--404 .error-link::after, .l-main--error .error-link::after {
  background: linear-gradient(to right, #039ddc, #0058ea);
  bottom: 0;
  content: "";
  display: block;
  height: 1px;
  left: 0;
  position: absolute;
  width: 100%;
}
.l-main--404 .l-main__inner, .l-main--error .l-main__inner {
  padding: 120px 0;
}
.l-main--404 .c-btn, .l-main--error .c-btn {
  margin: 40px auto 0;
}

.no-link {
  opacity: 0.4 !important;
  pointer-events: none !important;
}
.no-link--ba {
  pointer-events: none !important;
}
.no-link--ba::before, .no-link--ba::after {
  opacity: 0.4 !important;
  pointer-events: none !important;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
.c-pager__list {
  color: #9a947e;
  display: flex;
  gap: 0.6rem;
  justify-content: right;
  margin-top: 2rem;
  padding-right: 0.5rem;
}

.c-pager__list-item {
  display: flex;
  position: relative;
}
.c-pager__list-item.is-prev a {
  padding-left: 1.5rem;
}
.c-pager__list-item.is-prev a::before {
  content: "<";
  display: block;
  left: 0;
  position: absolute;
  top: 0;
}
.c-pager__list-item.is-next a {
  padding-right: 1.5rem;
}
.c-pager__list-item.is-next a::before {
  content: ">";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
}

.c-pager__list-item.is-current {
  display: none;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
.c-grid-columns {
  align-items: flex-start;
  display: grid;
  gap: 4.5rem;
  grid-template-columns: 1fr 3.9fr;
}

.c-heading {
  overflow: hidden;
  width: 20.2rem;
}
.c-heading::before {
  content: "";
  display: block;
  height: 120%;
  position: absolute;
  right: 50%;
  rotate: 24deg;
  top: -6%;
  width: 1.2rem;
  z-index: -1;
}

.c-heading__ttl {
  align-items: center;
  background-color: #9a947e;
  border-radius: 6px;
  color: #fff;
  display: flex;
  font-size: 1.8rem;
  height: 4.3rem;
  justify-content: center;
  letter-spacing: 0.84em;
  text-align: center;
  text-indent: 0.84em;
}

.c-heading__p {
  background-color: #fff;
  color: #9a947e;
  font-size: 2rem;
  letter-spacing: 0;
  line-height: 1.45;
  margin-bottom: 19.5rem;
  margin-right: 21.1822660099%;
  margin-top: 0.9rem;
  padding-block: 0.4rem 0.7rem;
  text-align: right;
}
.c-heading__p--info {
  background-color: #e0eaf0;
}

.c-grid__heading {
  text-align: center;
}

.c-grid__ttl {
  font-size: 4.5rem;
  letter-spacing: 0.1em;
}
.c-grid__ttl--blue {
  color: #388ab8;
}
.c-grid__ttl--yellow {
  color: #756d4f;
}

.c-grid__ttl--sub {
  font-size: 2.1rem;
  font-weight: 600;
  margin-top: 1.8rem;
}

.c-heading__content {
  display: contents;
}

.c-top-list__heading {
  align-items: end;
  display: flex;
  gap: 2.3rem;
  height: 3.6rem;
  justify-content: end;
}

.c-top-list__h3,
.c-top-list__p {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.15em;
}

.c-top-list__link {
  align-items: center;
  aspect-ratio: 135.6/35;
  border: 1px solid #9a947e;
  border-radius: 40px;
  color: #9a947e;
  display: flex;
  font-size: 1.3rem;
  gap: 0.9rem;
  justify-content: center;
  transition: 0.5s;
  translate: 0 30%;
  width: 13.56rem;
}
.c-top-list__link p {
  font-weight: 700;
}

.c-top-list__link-icon svg {
  aspect-ratio: 13.6/8;
  width: 1.36rem;
}

.c-top-list__ul {
  padding-top: 5rem;
}

.c-top-list__li {
  border-top: 0.5px dashed #999999;
}
.c-top-list__li:last-child {
  border-bottom: 0.5px dashed #999999;
}
.c-top-list__li a {
  align-items: center;
  display: flex;
  gap: 1rem;
  height: 100%;
  padding-block: 1.6rem 1.9rem;
  transition: 0.5s;
  width: 100%;
}

.c-top-list__time {
  font-size: 1.2rem;
  font-weight: 700;
  width: 9.3rem;
}

.c-top-list__ttl {
  flex: 1;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.5;
}

.c-cta-btn {
  align-items: center;
  background-color: #535f5f;
  border-radius: 6px;
  color: #fff;
  display: flex;
  font-size: 2.1rem;
  font-weight: 400;
  justify-content: center;
  letter-spacing: 0.04em;
}
.c-cta-btn a {
  align-items: center;
  aspect-ratio: 190/41;
  display: flex;
  justify-content: center;
  width: 19rem;
}

.c-cta-sns {
  aspect-ratio: 1;
  width: 5.2rem;
}

.c-to-top {
  aspect-ratio: 47/51;
  position: absolute;
  right: 6.5%;
  translate: 0 -7.8rem;
  width: 4.7rem;
  z-index: 1;
}

.c-to-top.appear {
  animation: appear 0.5s forwards;
  z-index: 10;
}

.c-to-top.out {
  animation: out 0.5s forwards;
  pointer-events: none;
  z-index: -1;
}

@keyframes appear {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.c-pager__button--none {
  display: none;
}

.c-pager__list-item.is-current {
  pointer-events: none;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
/* -------------------------------------------*/
.p-company {
  margin-top: 2.1rem;
  padding-bottom: 14.5rem;
}

.p-company__grid-heading {
  gap: 1.17rem;
}
.p-company__heading::before {
  background-color: #da6865;
  right: 42%;
}

.p-company__heading-p {
  margin-bottom: 14.5rem;
}

.p-company__heading-text {
  font-family: serif;
  font-size: 4.9rem;
  line-height: 1.193877551;
  padding-left: 12.5rem;
}

.p-company__heading-description {
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: -0.005em;
  line-height: 1.7;
  margin-top: 2.1rem;
  max-width: 59.5rem;
  padding: 1.2rem 2rem 1.2rem 3.8rem;
  position: relative;
}
.p-company__heading-description::before {
  background-color: #da6865;
  bottom: 0;
  clip-path: polygon(5% 0, 100% 0%, 95% 100%, 0% 100%);
  content: "";
  display: block;
  left: 0;
  opacity: 0.51;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}

.p-company__messege {
  align-items: flex-end;
  display: grid;
  gap: 3rem;
  grid-template-columns: 1fr 20.1rem;
}

.p-company__en {
  aspect-ratio: 182.6/11.6;
  margin-inline: auto;
  width: 18.2rem;
}

.p-company__messege-textarea {
  margin-top: 8.2rem;
}

.p-company__h3 {
  font-size: 2rem;
  font-weight: 700;
  margin-top: 2.1rem;
  text-align: center;
}

.p-company__messege-text {
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  line-height: 1.6;
  margin-top: 3.8rem;
}

.p-company__name {
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.3;
  margin-left: auto;
  margin-top: 1rem;
  text-align: right;
  width: -moz-fit-content;
  width: fit-content;
}

.p-company__massege-image {
  aspect-ratio: 201.5/186.5;
}

.p-company__banner {
  display: grid;
  grid-template-areas: "g-1_2 g-1_2" "g-3 g-4";
  grid-template-columns: 50.1% 1fr;
  grid-template-rows: repeat(2, 31.8rem);
  margin-top: 6.4rem;
}

.p-company__banner-1_2 {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: g-1_2;
}

.p-company__banner-3 {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: g-3;
}

.p-service__container > .p-company__banner-3 {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}
.p-company__banner-3 img {
  -o-object-fit: cover;
  object-fit: cover;
}

.p-company__banner-4 {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
  align-items: center;
  display: flex;
  grid-area: g-4;
  justify-content: center;
}

.p-service__container > .p-company__banner-4 {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
}
.p-company__banner-4 img {
  aspect-ratio: 370.8/55.2;
  width: 71.0617094672%;
  -o-object-fit: contain;
  object-fit: contain;
}

.p-company__detail {
  align-items: flex-start;
  display: grid;
  gap: 3rem;
  grid-template-columns: 18.52rem 1fr;
  margin-top: 9.5rem;
}

.p-company__detail-logo {
  padding-top: 4rem;
}

.p-company__detail-wrapper {
  border-bottom: 1px solid #000000;
  padding-bottom: 0.8rem;
}

.p-company__detail-container {
  border-top: 1px solid #000000;
  font-size: 1.4rem;
  padding-top: 1.3rem;
}
.p-company__detail-container--1 {
  padding-bottom: 1.7rem;
}
.p-company__detail-container--2 {
  padding-bottom: 0.8rem;
}

.p-company__detail-h3 {
  padding-left: 1em;
  position: relative;
}
.p-company__detail-h3::before {
  content: "□";
  display: block;
  left: 0;
  position: absolute;
  top: 0;
}

.p-company__detail-list-container {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-top: 3rem;
}

.p-company__detail-list:not(li:first-child, li:nth-child(2)) {
  line-height: 1.2;
}

.p-company__detail-dl {
  display: grid;
  gap: 0.8rem;
  margin-top: 3rem;
}

.p-company__detail-dl-box {
  display: grid;
  gap: 3rem;
  grid-template-columns: 4.3em 1fr;
}
.p-company__detail-dl-box dt {
  -moz-text-align-last: justify;
  text-align-last: justify;
}

.p-company__detail-grid {
  align-items: center;
  display: grid;
  gap: 1.6rem;
  grid-template-columns: 1fr 29.2326431181% 29.2326431181%;
}

.p-service__container > .p-company__detail-grid-1 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  }

.p-company__detail-address {
  margin-top: 3rem;
}

.p-company__detail-p {
  line-height: 3;
  margin-top: 1em;
}
.p-company__detail-p--2 {
  margin-top: 0.2rem;
}

.p-service__container > .p-company__detail-grid-2 {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  }

.p-company__detail-adress {
  line-height: 1.4;
  margin-top: 0.5rem;
}
.p-company__detail-adress a {
  display: inline;
  text-decoration: underline;
}
.p-company__detail-adress a[href^="tel:"] {
  pointer-events: none;
  text-decoration: none;
}

/* -------------------------------------------*/
.p-archive-construction__columns {
  gap: 1.4rem;
}

.p-construction__heading::before {
  background-color: #e4aa3d;
}

.p-archive__h3-container--construction {
  border-bottom: 1px solid #000000;
  display: flex;
  justify-content: space-between;
  padding-bottom: 1.5rem;
}

.p-archive-construction__h3 {
  font-size: 2.6rem;
  font-weight: 500;
}

.p-archive-construction__tax-container {
  display: flex;
  gap: 0.6rem;
}

.p-archive-construction__tax-list {
  display: grid;
  gap: 0.6rem;
  grid-template-columns: 1fr 1fr;
}

.p-archive-construction__tax-link {
  display: flex;
}

.p-archive-construction__li {
  margin-top: 2.95rem;
}

.p-archive-construction__li-link {
  align-items: baseline;
  display: flex;
  gap: 1.8rem;
}

.p-archive-construction__image {
  aspect-ratio: 94.7/56.6;
  overflow: hidden;
  width: 9.47rem;
}

.p-archive-construction__text-container {
  align-items: center;
  border-bottom: 1px dotted #9a947e;
  display: flex;
  flex: 1;
  padding-bottom: 1.6rem;
}

.p-archive-construction__tax {
  color: #fff;
  font-size: 1.3rem;
  padding: 0.8rem 0.6rem;
  text-align: center;
}
.p-archive-construction__tax--aircon {
  background-color: #40bae0;
}
.p-archive-construction__tax--electric {
  background-color: #f69b00;
}

.p-archive-construction__post {
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  padding: 0.8rem 0.9rem;
  text-align: center;
}
.p-archive-construction__post--corporation {
  background-color: #ccebeb;
}
.p-archive-construction__post--consumer {
  background-color: #e9e092;
}

.p-archive-construction__time {
  margin-left: 5rem;
}

.p-archive-construction__ttl {
  margin-left: 2.8rem;
}

.p-archive__messege--to-c {
  margin-top: 8.5rem;
}

.p-single-construction__columns {
  gap: 1.2rem;
}

.p-single-construction__body {
  max-width: 74.6rem;
  width: 91.8%;
}

.p-single-construction {
  margin-top: 2.4rem;
  padding-bottom: 7.2rem;
}

.p-single-construction__h3 {
  border-bottom: 1px dotted #999999;
  font-size: 2.6rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  padding-bottom: 1.8rem;
}

.p-single-construction__container {
  margin-top: 2.6rem;
}

.p-single-construction__dl-box {
  align-items: center;
  border-bottom: 1px solid #676767;
  display: flex;
  gap: 1.8rem;
  padding-block: 0.9rem;
}
.p-single-construction__dl-box--item {
  border-bottom: unset;
  padding-block: unset;
}
.p-single-construction__dl-box:nth-child(2) {
  margin-top: 2.1rem;
}
.p-single-construction__dl-box:last-child {
  border-bottom: unset;
}
.p-single-construction__dl-box--textarea {
  align-items: flex-start;
  border-top: 1px solid #676767;
  padding-block: 1.5rem 0.6rem;
}
.p-single-construction__dl-box--textarea--before {
  align-items: flex-start;
  padding-block: 0.7rem 0.9rem;
}
.p-single-construction__dl-box--before {
  margin-top: 1rem;
}

.p-single-construction__dt-item {
  align-items: center;
  aspect-ratio: 81/26;
  background-color: #9a947e;
  color: #fff;
  display: flex;
  font-size: 1.5rem;
  font-weight: 700;
  justify-content: center;
  line-height: 1.2666666667;
  width: 8.1rem;
}

.p-single-construction__dd-item {
  font-size: 1.8rem;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.2777777778;
}

.p-single-construction__dt {
  align-items: center;
  aspect-ratio: 81/26;
  border: 1px solid #9a947e;
  display: flex;
  font-size: 1.3rem;
  justify-content: center;
  line-height: 1.1538461538;
  width: 8.1rem;
}

.p-single-construction__dd {
  flex: 1;
  font-size: 1.3rem;
  line-height: 1.1538461538;
  padding-left: 0.5em;
}
.p-single-construction__dd--textarea {
  line-height: 2;
  max-width: 57rem;
}

.p-single-construction__image-l {
  aspect-ratio: 742/475;
  margin-top: 1.6rem;
  width: 99.4%;
}

.p-single-construction__image-s-container {
  display: grid;
  gap: 7.3%;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 4.8rem;
  padding-bottom: 2.4rem;
}
.p-single-construction__image-s-container--before {
  border-bottom: unset;
  margin-top: 0;
}

.p-single-construction__dt-before {
  align-items: center;
  aspect-ratio: 81/26;
  border: 1px solid #deb156;
  display: flex;
  font-size: 1.3rem;
  justify-content: center;
  width: 8.1rem;
}

.p-single-construction__botton {
  display: grid;
  grid-template-columns: 0.4fr 1.4fr 0.26fr;
  padding-top: 4.2rem;
}

.p-single-construction__to-other {
  align-items: flex-start;
  color: #9a947e;
  display: flex;
  font-size: 1.5rem;
  gap: 0.9rem;
  padding-top: 0.8rem;
}
.p-single-construction__to-other a {
  height: auto;
}

/* -------------------------------------------*/
.p-contact {
  margin-top: 2.1rem;
  padding-bottom: 10.5rem;
}

.p-contact__heading::before {
  background-color: rgba(154, 148, 126, 0.46);
}

.p-contact__ttl {
  letter-spacing: 0.2em !important;
  text-indent: 0.4em;
}

.p-contact__image-logo {
  aspect-ratio: 342/104;
  margin-left: 17.6767676768%;
  margin-top: 3.4rem;
  width: 43.1818181818%;
}

.p-contact__tel-container {
  margin-left: 7.5757575758%;
  margin-top: 7.4rem;
  text-align: center;
  width: 62.5%;
}

.p-contact__tel-text {
  font-size: 2.6rem;
}

.p-contact__tel-number {
  aspect-ratio: 495/51;
  margin-inline: auto;
  margin-top: 1.4rem;
}
.p-contact__tel-number a[href^="tel:"] {
  pointer-events: none;
}

.p-contact__tel-time {
  font-size: 1.8rem;
  margin-top: 1rem;
}

.p-contact__mail-container {
  margin-left: 2.904040404%;
  margin-top: 6.5rem;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
}

.p-contact__mail-heading {
  color: #535f5f;
  font-size: 2.5rem;
  font-weight: 600;
}

.p-contact__mail-text {
  font-size: 1.8rem;
  line-height: 1.2962962963;
  margin-top: 2rem;
}

.smf-form--business {
  font-size: 1.8rem;
  margin-inline: auto;
  margin-top: 4rem;
  width: 90%;
}
.smf-form--business p {
  color: #9a947e;
  font-size: 1.2rem;
  line-height: 1.5;
  margin-top: 2rem;
}

.smf-form--business .smf-item__col--label {
  align-content: center;
  background-color: unset;
  background-color: #D1CEC4;
  border-left: 1px solid #6b6b6b;
  border-right: unset;
  border-top: 1px solid #6b6b6b;
  flex: unset;
  max-width: unset;
  padding-bottom: 2rem;
  padding-left: 9rem;
  position: relative;
  width: 32.7rem;
}
.smf-form--business .smf-item__col--label::before {
  background-color: #D1CEC4;
  bottom: -1px;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  top: 0;
  width: 5.3rem;
  z-index: 1;
}

.smf-first .smf-item__col--label {
  padding-top: 4rem;
}

.flex-start .smf-item__col--label {
  align-content: flex-start;
  border-bottom: 1px solid #6b6b6b;
}

.smf-form--business:last-child .smf-item__col--label {
  align-items: flex-start;
}
.smf-form--business:last-child .smf-item__col--label::before {
  display: none;
}

.smf-form--business .smf-item {
  border: unset;
}

.smf-item__col--controls {
  align-content: end;
  background-color: #fff;
  border-right: 1px solid #6b6b6b;
  border-top: 1px solid #6b6b6b;
  flex: 1 !important;
  padding: 1.6rem 1.6rem 1.6rem 3rem !important;
}

.flex-start .smf-item__col--controls {
  border-bottom: 1px solid #6b6b6b;
  padding-bottom: 3rem;
}

.smf-radio-buttons-control__control {
  display: flex;
  gap: 2.5rem;
}

.smf-form .smf-radio-button-control {
  align-items: center;
  gap: 1rem;
}

.smf-button-control__control {
  background-color: #fff !important;
  background-image: unset !important;
  border: 1px solid #9a947e !important;
  box-shadow: 0px 0px 4px 0px #9a947e;
  color: #9a947e !important;
  font-size: 1.8rem;
  margin-top: 1.4rem;
  padding: 1.2rem 3rem !important;
  transition: 0.5s !important;
}

.smf-error-messages {
  font-size: 1.2rem;
}

.smf-form .smf-radio-button-control__control:checked {
  background-color: #fff;
  border-color: #535f5f;
}

.smf-form .smf-radio-button-control__control:checked:before {
  background-color: #000000;
  height: 10px;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  width: 10px;
}

/* -------------------------------------------*/
.p-error {
  padding-block: 7rem;
}

.p-error__ttl {
  text-align: center;
}

.p-error__h2 {
  font-size: 2.8rem;
  font-weight: 700;
}

.p-error__msg {
  margin-top: 2rem;
}

.p-error__btn {
  margin-inline: auto;
  margin-top: 3.5rem;
  width: -moz-fit-content;
  width: fit-content;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
.scroll {
  bottom: 15rem;
  color: #fff;
  left: 3rem;
  opacity: 0;
  position: absolute;
  writing-mode: vertical-rl;
  z-index: 110;
}

/* 線のアニメーション部分 */
.scroll::before {
  animation: scroll 2s infinite;
  background-color: #fff;
  bottom: -115px;
  content: "";
  height: 100px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}

/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
h1.p-top-fv__logo {
  height: auto;
  left: 4rem;
  position: absolute;
  top: 3rem;
  transition: 0.5s;
  width: 30rem;
  z-index: 110;
}

body.is-active {
  height: 100vh;
}

.p-top-fv {
  height: 100vh;
  overflow: hidden;
  position: relative;
  z-index: 10;
}
.p-top-fv__inner {
  display: flex;
  flex-flow: column;
  height: inherit;
  justify-content: space-between;
  margin: 0 auto;
  max-width: 124rem;
  padding-inline: 1.5rem;
  position: relative;
}
.p-top-fv__head {
  color: #fff;
  padding-left: 3rem;
  padding-top: 10rem;
  position: relative;
  text-align: left;
  z-index: 30;
}
.p-top-fv__head h2,
.p-top-fv__head h1 {
  font-size: 9rem;
  letter-spacing: 0;
  text-shadow: 4px 3px 2px rgba(0, 0, 0, 0.2);
}
.p-top-fv__head p.c-head__catch {
  font-size: 4.3rem;
  text-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4);
}
.p-top-fv__head p.c-head__catch-bottom {
  font-size: 2.1rem;
  letter-spacing: 0.12em;
  line-height: 1.6;
  margin-top: 0.8rem;
  padding-left: 1.5rem;
  text-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4);
}
.p-top-fv__cta {
  align-items: center;
  display: flex;
  justify-content: space-between;
  padding-bottom: 3.5rem;
  position: relative;
  z-index: 190;
}
.p-top-fv__sns-links {
  display: flex;
  gap: 2rem;
  padding-left: 5.3rem;
  position: relative;
  z-index: 90;
}
.p-top-fv__bars {
  display: flex;
}
.p-top-fv__body {
  padding-bottom: 3.5rem;
  position: relative;
}
.p-top-fv__contact {
  padding-right: 7.5rem;
}
.p-top-fv__sns-links.u-pt {
  margin-top: 1rem;
  padding-left: 0;
}
.p-top-fv__sns-link img {
  height: auto;
  width: 5rem;
  -o-object-fit: contain;
  object-fit: contain;
}

p.c-head__catch.loading__text01.is-show {
  letter-spacing: -0.08em;
  line-height: 1.4;
  margin-top: 1.6rem;
  padding-left: 1rem;
}

.p-top-fv__sns-links.u-pt {
  margin-top: 1rem;
  padding-left: 0;
}

a.p-top-fv__contact-link {
  align-items: center;
  background-color: #535F5F;
  border: 1px solid #535f5f;
  border-radius: 0.7rem;
  color: #fff;
  display: block;
  display: flex;
  font-weight: 400;
  height: 5rem;
  justify-content: center;
  width: 16.4rem;
}

.p-top-fv__bars01,
.p-top-fv__bars03 {
  background: linear-gradient(to bottom, rgba(0, 0, 47, 0) 0%, rgba(0, 0, 47, 0.9) 60%, rgb(20, 20, 50) 100%);
  position: relative;
  width: 64rem;
  z-index: 20;
}

.p-top-fv__bars02 {
  background: linear-gradient(to top, rgb(20, 20, 50) 0%, rgba(0, 0, 47, 0.9) 40%, rgba(0, 0, 47, 0) 100%);
  position: relative;
  width: 64rem;
  z-index: 20;
}

.p-top-fv__bars-black {
  position: relative;
  width: 64rem;
  z-index: 20;
}

.p-top-fv__bars-black__shadow {
  background: #000;
  display: block;
  height: 100%;
  overflow: hidden;
  transform: skewX(-25deg);
  width: 100%;
}

.p-top-fv__bars01-img-in {
  left: -8.9rem;
  -o-object-fit: fill;
  height: 56.5vh;
  object-fit: fill;
  overflow: hidden;
  position: relative;
  transform: skewX(25deg);
  width: 64rem;
  width: 91%;
}

.p-top-fv__bars01-img-in::before {
  background-color: #338358;
  content: "";
  display: inline-block;
  height: 1.2rem;
  left: calc(50% - 39.5rem);
  opacity: 1;
  position: absolute;
  rotate: -65deg;
  top: calc(50% - 58rem);
  transform: translate(-50%, -50%);
  width: 178%;
}

.p-top-fv__bars02-img-in {
  left: -13.9rem;
  -o-object-fit: fill;
  height: 56.5vh;
  object-fit: fill;
  overflow: hidden;
  position: relative;
  transform: skewX(25deg);
  width: 100%;
}

.p-top-fv__bars02-img-in::before {
  background-color: #dca640;
  content: "";
  display: inline-block;
  height: 1.2rem;
  left: calc(50% - 45.8rem);
  opacity: 1;
  position: absolute;
  rotate: -65deg;
  top: calc(50% - 65.6rem);
  transform: translate(-50%, -50%);
  width: 206%;
}

.p-top-fv__bars03-img-in {
  left: 1.1rem;
  -o-object-fit: fill;
  height: 56.5vh;
  object-fit: fill;
  overflow: hidden;
  position: relative;
  transform: skewX(25deg);
  width: 91%;
}

.p-top-fv__bars03-img-in::before {
  background-color: #d06562;
  content: "";
  display: inline-block;
  height: 1.2rem;
  left: calc(50% - 59.3rem);
  opacity: 1;
  position: absolute;
  rotate: -65deg;
  top: calc(50% - 61rem);
  transform: translate(-50%, -50%);
  width: 179%;
}

.p-top-fv__link {
  cursor: pointer;
  display: block;
  height: 100%;
  width: -moz-fit-content;
  width: fit-content;
}

.p-top-fv__bars01 {
  bottom: 0;
  height: 100%;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  right: 37rem;
  transform: skewX(-25deg);
  width: 17rem;
  z-index: 60;
}

.p-top-fv__bars01.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
  opacity: 1;
}

.p-top-fv__bars02.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
  opacity: 1;
}

.p-top-fv__bars03.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
  opacity: 1;
}

.p-top-fv__bars01-img,
.p-top-fv__bars03-img {
  bottom: 0;
  position: absolute;
}

.p-top-fv__bars02-img {
  position: absolute;
  top: 0;
}

.p-top-fv__bars02 {
  bottom: 0;
  height: 100%;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  right: 20rem;
  transform: skewX(-25deg);
  width: 17rem;
  z-index: 50;
}

.p-top-fv__bars03 {
  bottom: 0;
  height: 100%;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  right: 3rem;
  transform: skewX(-25deg);
  width: 17rem;
}

.p-top-fv__bars-black {
  height: 100%;
  left: -2rem;
  opacity: 0;
  position: absolute;
  width: 17rem;
  z-index: 10;
  -o-object-fit: fill;
  object-fit: fill;
}

.p-top-fv__sns-links {
  display: flex;
  gap: 1.5rem;
}

.loading__start {
  align-items: center;
  animation: startFadeOut 3s forwards;
  background: #000;
  display: flex;
  inset: 0;
  justify-content: center;
  position: fixed;
  z-index: 9999;
}

/* ロゴアニメーション */
.loading__logo {
  animation: logoFade 3s forwards;
  color: #fff;
  font-size: 2rem;
  opacity: 0;
  width: 16.3rem;
}

/* ロゴの出現 → 少し表示 → フェードアウト */
@keyframes logoFade {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  20% {
    opacity: 1;
    transform: scale(1);
  }
  70% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform: scale(1.05);
  }
}
/* 背景も一緒に消える */
@keyframes startFadeOut {
  0% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
.loading__bg--cloud,
.loading__bg--mountain {
  background-position: center;
  background-size: cover;
  inset: 0;
  opacity: 0;
  position: absolute;
}

.loading__bg--cloud {
  background: url(../images/top/sky_fv.webp) no-repeat bottom center/cover;
  inset: 0;
  opacity: 0;
  position: absolute;
  transition: opacity 3s ease;
  z-index: 1;
}

.loading__bg--mountain {
  background: url(../images/top/mount_fv.webp) no-repeat center 40%/cover;
  position: absolute;
  transition: opacity 1s ease;
  z-index: 1;
}

.loading__bg--cloud.is-show {
  opacity: 1;
}

@keyframes slideFadeIn {
  0% {
    opacity: 0;
    transform: translateX(-50px);
    /* 左から */
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes startFadeOut {
  0% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    visibility: hidden;
  }
}
.loading__bg--mountain.is-show {
  opacity: 1;
}

.loading__text {
  color: #fff;
  pointer-events: none;
  position: relative;
  text-align: center;
  z-index: 120;
}

.loading__title,
.loading__subtitle,
.loading__text01,
.loading__subtext {
  opacity: 0;
  text-align: left;
  transform: translateY(0);
  transition: opacity 0.8s ease, transform 0.8s ease;
  width: 100%;
}

.loading__title.is-show,
.loading__subtitle.is-show {
  font-weight: 500;
  opacity: 1;
  transform: translateY(0);
}

.loading__title.is-hide {
  display: none;
}

.loading__text01.is-show,
.loading__subtext.is-show {
  opacity: 1;
  transform: translateY(0);
}

.p-top-fv__bars01-img {
  left: -16.6rem;
  transform: scaleY(0);
  transform-origin: top;
  width: 73.5rem;
}

.p-top-fv__bars02-img {
  left: -11.2rem;
  transform: scaleY(0);
  transform-origin: top;
  width: 67rem;
}

.p-top-fv__bars03-img {
  left: -12.6rem;
  transform: scaleY(0);
  transform-origin: top;
  width: 79rem;
}

.p-top-fv__bars01-img.is-animate {
  animation: moveToBottom 0.7s cubic-bezier(0.85, 0, 0.175, 1) forwards;
  opacity: 0;
}

.p-top-fv__bars02-img.is-animate {
  animation: moveToTop 0.9s cubic-bezier(0.85, 0, 0.175, 1) forwards;
  opacity: 0;
}

.p-top-fv__bars03-img.is-animate {
  animation: moveToBottom 0.9s cubic-bezier(0.85, 0, 0.175, 1) forwards;
  opacity: 0;
}

.p-top-fv__bars-black.is-animate {
  animation: TextFadeIn 0.8s ease-out forwards;
  opacity: 1;
}

.p-top-fv__cta {
  opacity: 0;
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.p-top-fv__cta.is-show {
  opacity: 1;
  transform: translateY(0);
}

.p-top-fv__cta-sp {
  opacity: 0;
  position: relative;
  transition: opacity 0.8s ease, transform 0.8s ease;
  z-index: 100;
  z-index: 130;
}

.p-top-fv__cta-sp.is-show {
  opacity: 1;
  transform: translateY(0);
}

.scroll.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
  opacity: 1;
}

.p-top-fv__bars02-inner {
  height: 100%;
  position: relative;
  width: 100%;
}

.p-top-fv__bars02 img.p-top-fv__bars-text {
  position: absolute;
  -o-object-fit: contain;
  bottom: -35rem;
  height: auto;
  left: calc(50% - 4rem);
  object-fit: contain;
  opacity: 0;
  rotate: -24deg;
  transform: translate(-50%, -50%);
  width: 13rem;
}

.p-top-fv__bars02 img.p-top-fv__bars-text.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideSotoFadeIn {
  0% {
    opacity: 0;
    transform: translateX(-100vw);
  }
  30% {
    opacity: 0.3;
  }
  40% {
    opacity: 0.4;
  }
  50% {
    opacity: 0.5;
  }
  70% {
    opacity: 0.6;
  }
  70% {
    opacity: 0.7;
  }
  80% {
    opacity: 0.8;
  }
  90% {
    opacity: 0.9;
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes moveToTop {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes moveToBottom {
  0% {
    opacity: 0;
    transform: translateY(-100%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes barDown {
  to {
    transform: scaleY(1);
    transform-origin: top;
  }
}
@keyframes barUp {
  to {
    transform: scaleY(1);
    transform-origin: bottom;
  }
}
@keyframes TextFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-top-fv__bottom-black {
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.3) 30%, rgba(0, 0, 0, 0.6) 60%, rgba(0, 0, 0, 0.9) 100%);
  bottom: 0;
  height: 40%;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  width: 100%;
  z-index: 20;
}

.p-top-fv__bottom-black.is-show {
  animation: TextFadeIn 0.5s ease-out forwards;
  opacity: 1;
}

/* -------------------------------------------*/
/* -------------------------------------------
archive-----------------------------------------*/
.p-archive {
  margin-top: 2.3rem;
  padding-bottom: 6rem;
}

.p-archive-info__columns {
  gap: 1rem;
}

.p-archive-info__heading::before {
  background-color: #2192ff;
}

.p-archive__body {
  padding-top: 5.8rem;
}

.p-archive__ul {
  padding-left: 11rem;
  padding-top: 3.4rem;
}

.p-archive__h3 {
  border-bottom: 1px solid #000;
  font-size: 2.5rem;
  font-weight: 500;
  padding-bottom: 1.6rem;
}

.p-archive__li {
  border-bottom: 1px dotted #9a947e;
  margin-top: 3.55rem;
}
.p-archive__li:first-child {
  margin-top: 0;
}

.p-archive__li-link {
  align-items: center;
  display: flex;
  gap: 2rem;
  padding-block: 1.8rem;
  padding-left: 3.5rem;
}

.p-archive__messege {
  margin-top: 8.5rem;
  padding-left: 15.5rem;
  text-align: center;
  width: -moz-fit-content;
  width: fit-content;
}

.p-archive__h4 {
  color: #9a947e;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: -0.06em;
}

.p-archive__massege-text {
  font-size: 1.3rem;
  letter-spacing: -0.06em;
  line-height: 1.5384615385;
  margin-top: 1.5rem;
}

.p-archive__pager {
  margin-top: 2.6rem;
  padding-right: 1.2rem;
}

/* -------------------------------------------
single-----------------------------------------*/
.p-single__info {
  margin-top: 2.3rem;
  padding-bottom: 7rem;
}

.p-single-info__body {
  padding-right: 5.7rem;
  padding-top: 5.3rem;
}

.p-single-info__columns {
  gap: 1.5rem;
}

.p-single-info__container {
  background-color: rgba(154, 148, 126, 0.19);
  margin-top: 4.7rem;
  padding: 2rem 2rem 3.6rem;
}

.p-single-info__heading {
  align-items: center;
  border-bottom: 1px solid #676767;
  display: flex;
  gap: 2rem;
  padding-bottom: 1.6rem;
}

.p-single-info__h3 {
  font-size: 3rem;
}

.p-single-info__time {
  font-size: 1.3rem;
  letter-spacing: -0.04em;
}

.p-single-info__h4 {
  font-size: 1.8rem;
  font-weight: 700;
}

.p-single-info__content {
  font-size: 1.3rem;
  line-height: 2;
  margin-top: 1.5rem;
  padding-left: 8.3rem;
}

.p-single-info__bottom {
  display: grid;
  grid-template-columns: 0.55fr 1.3fr 0.28fr;
  padding-top: 18rem;
}

.p-service__container > .p-single-info__btn {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
  }

.p-single-info__btn a {
  align-items: center;
  border: 1px solid #9a947e;
  border-radius: 40px;
  color: #9a947e;
  display: flex;
  font-size: 1.3rem;
  gap: 0.6rem;
  height: 3.5rem;
  justify-content: center;
  width: 13.5rem;
}

.p-single-info__btn-svg {
  aspect-ratio: 13/8;
  width: 1.3rem;
}
.p-single-info__btn-svg .cls-1 {
  transition: 0.5s;
}

.p-single-info__btn-p {
  font-weight: 700;
}

.p-single-info__messege {
  padding-top: 0.8rem;
  text-align: center;
}
.p-service__container > .p-single-info__messege {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
  }

.p-single-info__messege-text {
  margin-top: 3.6rem;
}

.p-single-info__to-other {
  align-items: flex-start;
  color: #9a947e;
  display: flex;
  font-size: 1.5rem;
  gap: 0.9rem;
  padding-top: 0.8rem;
}
.p-single-info__to-other a {
  height: auto;
}

/* -------------------------------------------*/
.p-policy {
  padding-block: 7rem;
}

.p-policy__section {
  margin: 3rem auto 0 !important;
}

.p-policy__h2 {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  padding-left: 1.2em;
  position: relative;
}
.p-policy__h2::before {
  color: #9a947e;
  content: "■";
  left: 0;
  position: absolute;
  top: 0;
}

.p-policy__p {
  font-size: 1.3rem;
  line-height: 2;
  margin-top: 1rem;
}

.p-policy__link {
  color: #9a947e;
  text-decoration: underline;
}

/* -------------------------------------------*/
.p-service {
  margin-top: 2.1rem;
  padding-bottom: 6.7rem;
}

.p-service__grid-heading {
  gap: 5.17rem;
}
.p-service__heading::before {
  background-color: #33875a;
  right: 42%;
}

.p-service__heading-p {
  margin-bottom: 14.5rem;
}

.p-service__heading-text {
  font-family: serif;
  font-size: 4.9rem;
  line-height: 1.193877551;
  padding-left: 3.5rem;
}

.p-service__heading-description {
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  line-height: 1.6;
  margin-top: 3.5rem;
  max-width: 59.5rem;
  padding: 1.2rem 1.6rem 1.2rem 4rem;
  position: relative;
}
.p-service__heading-description::before {
  background-color: #33875a;
  bottom: 0;
  clip-path: polygon(5% 0, 100% 0%, 95% 100%, 0% 100%);
  content: "";
  display: block;
  left: 0;
  opacity: 0.51;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}

.p-service__grid-aircon {
  align-items: unset;
  gap: 2.6rem;
  margin-top: 4.8rem;
}

.p-service__image-aircon {
  display: grid;
}

.p-service__image-container {
  padding-top: 5.2rem;
  width: 22.7rem;
}

.p-service__image {
  aspect-ratio: 227/221;
}

.p-service__aircon-body {
  flex: 1;
}

.p-service__heading-h3 {
  align-items: end;
  display: flex;
  justify-content: space-between;
}

.p-service__h3 {
  font-size: 4.5rem;
  letter-spacing: 0.1em;
}
.p-service__h3--aircon {
  color: #388ab8;
}
.p-service__h3--electric {
  color: #756d4f;
}

.p-service__heading-en {
  height: 3.4rem;
  padding-right: 4.2rem;
  position: relative;
}
.p-service__heading-en::before {
  bottom: 0;
  content: "";
  display: block;
  height: 4.2rem;
  position: absolute;
  right: 0;
  width: 2.5rem;
}
.p-service__heading-en--aircon {
  aspect-ratio: 270/34;
}
.p-service__heading-en--electric {
  aspect-ratio: 332/34;
}
.p-service__heading-en--aircon::before {
  background-color: rgba(168, 204, 224, 0.18);
}
.p-service__heading-en--electric::before {
  background-color: rgba(228, 202, 149, 0.39);
}

.p-service__body {
  display: flex;
  flex-direction: column;
}

.p-service__container {
  display: grid;
  flex-grow: 1;
  gap: 2.5rem;
  grid-template-areas: "g-1 g-2" "g-3 g-4";
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 25rem 1fr;
  margin-top: 1rem;
  padding: 2.2rem 2.8rem;
  position: relative;
}
.p-service__container::before {
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -2;
}
.p-service__container--aircon::before {
  background-color: rgba(168, 204, 224, 0.18);
}
.p-service__container--electric::before {
  background-color: rgba(228, 202, 149, 0.39);
}
.p-service__container::after {
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 66%;
  z-index: -1;
}
.p-service__container--aircon::after {
  background-color: rgba(168, 204, 224, 0.39);
}
.p-service__container--electric::after {
  background-color: rgba(228, 202, 149, 0.6);
}

.p-service__grid-image {
  aspect-ratio: 348/245;
}

.p-service__grid--grid01 {
  grid-area: g-1;
}

.p-service__container > .p-service__grid--grid01 {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}

.p-service__grid--grid02 {
  grid-area: g-2;
}

.p-service__container > .p-service__grid--grid02 {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
}

.p-service__grid--grid03 {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  grid-area: g-3;
}

.p-service__container > .p-service__grid--grid03 {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
}

.p-service__grid--grid04 {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
  grid-area: g-4;
}

.p-service__container > .p-service__grid--grid04 {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
}

.p-service__grid--grid03--aircon:before,
.p-service__grid--grid04--aircon:before {
  background-color: rgba(168, 204, 224, 0.39);
}

.p-service__grid--grid03--electric::before,
.p-service__grid--grid04--electric::before {
  background-color: rgba(228, 202, 149, 0.6);
}

.p-service__grid-h4 {
  font-size: 2.1rem;
  font-weight: 700;
}

.p-service__grid-text {
  font-size: 1.4rem;
  letter-spacing: -0.04em;
  line-height: 1.35;
  margin-top: 0.6rem;
  min-height: 8.4rem;
}

.p-service__grid-electric {
  align-items: unset;
  gap: 2.6rem;
  margin-top: 6.7rem;
}

.p-service__ul {
  display: grid;
  gap: 0.6rem;
  margin-top: 12.2rem;
  padding-left: 4.8rem;
}

.p-service__grid-list {
  gap: 5rem;
  grid-template-columns: 16rem 1fr;
}

.p-service__list-number {
  aspect-ratio: 160/280;
  margin-top: 0.8rem;
  padding-top: 6.1rem;
  position: relative;
  width: 16rem;
}
.p-service__list-number img {
  background-color: #fff;
  padding-bottom: 8.3rem;
  padding-top: 1.9rem;
  -o-object-fit: contain;
  object-fit: contain;
}
.p-service__list-number::before {
  background-color: #33875a;
  right: 50%;
  rotate: 19deg;
  top: -4%;
  width: 0.7rem;
}

.p-service__list-h4 {
  color: #33875a;
  font-family: serif;
  font-size: 4.9rem;
  letter-spacing: -0.01em;
}

.p-service__list-box {
  display: grid;
  grid-template-columns: 1fr 23.3rem;
  margin-top: 2rem;
  min-height: 15.7rem;
}
.p-service__list-box--1 {
  background-color: rgb(238, 238, 240);
}
.p-service__list-box--2 {
  background-color: rgba(51, 135, 90, 0.15);
}

.p-service__list-description {
  font-size: 1.4rem;
  line-height: 1.380952381;
  padding-left: 2.2rem;
  padding-top: 3.4rem;
}

.p-service__list-image {
  position: relative;
}
.p-service__list-image::before {
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
}
.p-service__list-image--1::before, .p-service__list-image--3::before {
  background-image: linear-gradient(90deg, rgb(238, 238, 240), rgba(238, 238, 240, 0));
}
.p-service__list-image--2::before {
  background-image: linear-gradient(90deg, rgb(225, 237, 230), rgba(51, 135, 90, 0));
}

.p-service__list-image--1 img {
  object-view-box: inset(50px 247px 111px 20px);
}

.p-service__list-image--2 img {
  object-view-box: inset(50px 160px 111px 20px);
}

.p-service__messege {
  margin-top: 3.8rem;
  padding-left: 11.5rem;
  text-align: center;
}

/* -------------------------------------------*/
.p-site_map {
  padding-block: 7rem;
}

.p-site_map__section {
  margin: 3rem auto 0 !important;
}

.p-site_map__h2 {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.5;
  padding-left: 1.2em;
  position: relative;
}
.p-site_map__h2::before {
  color: #9a947e;
  content: "■";
  left: 0;
  position: absolute;
  top: 0;
}

.p-site_map__grid {
  display: grid;
  gap: 2.5rem 2rem;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 2.5rem;
  padding-inline: 2rem;
}

.p-site_map__box a {
  align-content: center;
  border: 1px solid #9a947e;
  color: #9a947e;
  line-height: 1.5;
  padding-block: 1rem;
  text-align: center;
  transition: 0.5s;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
.p-top {
  padding-bottom: 14.6rem;
}

.p-top-service__heading::before {
  background-color: #33875a;
}

.p-top-service__body {
  display: grid;
  gap: 6.3291139241%;
  grid-template-columns: 1fr 1fr;
}

.p-top-service__grid {
  padding: 1.5rem 2.7rem;
  position: relative;
}
.p-top-service__grid:hover .p-top-service__grid-img img {
  opacity: 0.8;
  transform: scale(1.05);
}
.p-top-service__grid--blue {
  background-color: rgba(168, 204, 224, 0.21);
}
.p-top-service__grid--yellow {
  background-color: rgba(228, 202, 149, 0.21);
}
.p-top-service__grid::before {
  background-color: rgba(154, 148, 126, 0.5);
  bottom: 0;
  content: "";
  display: block;
  height: 5rem;
  left: 0;
  position: absolute;
  right: 0;
}

.p-top-service__grid-img {
  aspect-ratio: 330/224;
  background-color: #fff;
  margin-top: 1rem;
  overflow: hidden;
  padding: 0.4rem;
  position: relative;
  z-index: 1;
}
.p-top-service__grid-img img {
  transition: 0.5s;
}

.p-top-case {
  margin-top: 7.3rem;
}

.p-top-case__heading::before {
  background-color: #e4aa3d;
}

.p-top-case__body {
  padding-top: 2.8rem;
}

.p-top-info {
  margin-top: 3.2rem;
  padding-block: 2rem 4.4rem;
  position: relative;
}
.p-top-info::before {
  background-color: #e0eaf0;
  bottom: 0;
  content: "";
  display: block;
  left: -50%;
  position: absolute;
  top: 0;
  width: 200vw;
  z-index: -1;
}

.p-top-info__heading::before {
  background-color: #2192ff;
}

.p-top-info__body {
  padding-top: 2.8rem;
}

.p-top-company {
  gap: 4.1rem;
  height: 32.4rem;
  margin-top: 5.8rem;
  position: relative;
  transition: 0.5s;
}
.p-top-company::before {
  background-image: url(../images/common/future.webp);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  bottom: 0;
  content: "";
  display: block;
  left: -1rem;
  position: absolute;
  right: -1rem;
  top: 0;
  z-index: -2;
}
.p-top-company::after {
  background-color: #f5f6f6;
  box-shadow: 0px 0px 20px 20px #f5f6f6;
  content: "";
  display: block;
  height: 12.2rem;
  left: -1.1rem;
  position: absolute;
  top: 3rem;
  width: 33.4615384615%;
  z-index: -2;
}
.p-top-company:hover {
  opacity: 0.8;
}

.p-top-campany__heading::before {
  display: none;
}

.p-top-campany__heading::after {
  aspect-ratio: 160/318;
  background-image: url(../images/common/diagonal.svg);
  content: "";
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  width: 79.2079207921%;
  z-index: -1;
}

.p-top-campany__body {
  padding-top: 5rem;
}

.p-top-campany__ttl {
  -webkit-text-stroke: 2px #fff;
  font-family: serif;
  font-size: 4.9rem;
  text-stroke: 2px #fff;
  paint-order: stroke;
}

.p-top-company__heading-p {
  background-color: unset;
  margin-bottom: 13rem;
  margin-left: auto;
  width: -moz-fit-content;
  width: fit-content;
}

.p-top-campany__svg {
  aspect-ratio: 46/313;
  position: absolute;
  right: 0;
  top: 1rem;
  width: 4.6rem;
}
.p-top-campany__svg .cls-1 {
  opacity: 1;
}
.p-top-campany__svg .cls-2 {
  opacity: 1;
}

/* -------------------------------------------*/
/* -------------------------------------------*/
.u-db {
  display: block;
}

.u-dn {
  display: none;
}

.u-disp__less1023 {
  display: none;
}

.u-mask--c-black {
  filter: brightness(0);
}

.u-mask--c-white {
  filter: brightness(0) invert(1);
}

.u-con--md {
  margin: 0 auto;
  max-width: var(--content_width);
  padding-inline: 2rem;
}

.u-con--lg {
  margin: 0 auto;
  max-width: 90%;
}

.u-c-white {
  color: #fff;
}

.u-c--b-white {
  color: #fff;
}

.u-z-1 {
  z-index: -1;
}

.u-z1 {
  z-index: 1;
}

.u-z2 {
  z-index: 2;
}

.u-z3 {
  z-index: 3;
}

.u-z10 {
  z-index: 10;
}

.u-z50 {
  z-index: 50;
}

.u-z100 {
  z-index: 100;
}

.u-z999 {
  z-index: 999;
}

.u-padding-top {
  padding-top: 5.5rem;
}

@media screen and (max-width: 1500px){
  h1.p-top-fv__logo {
    left: 5rem;
  }
}

@media not all and (max-width: 1400px){
  html {
    font-size: 70%;
  }
}

@media screen and (max-width: 1400px){
  .p-to-grid {
    grid-template-columns: 140px 1fr;
  }
  .p-top-heading {
    width: auto;
  }
  .p-top-campany__heading::after {
    aspect-ratio: unset;
    background-repeat: no-repeat;
    height: 100%;
    top: 3%;
    width: 100%;
  }
}

@media screen and (max-width: 1200px){
  .p-top-fv__bars02 img.p-top-fv__bars-text {
    left: calc(50% - 6rem);
  }
}

@media not all and (max-width: 1080px){
  .l-wrapper {
    align-items: center;
    display: flex;
    flex-direction: column;
    height: 100%;
    margin: 0 auto;
    min-height: 100vh;
    position: relative;
    text-align: left;
    width: 100%;
  }
  .u-st {
    display: none !important;
  }
}

@media screen and (max-width: 1080px){
  :root {
    --content_width: 750px;
    --content-both_space: 15px;
    --header_height: 90px;
  }
  html {
    font-size: 57.5%;
  }
  input[type=text],
  input[type=date],
  input[type=password],
  input[type=email],
  input[type=time],
  input[type=tel],
  input[type=number] {
    padding: 10px;
  }
  textarea {
    height: 170px;
  }
  input[type=radio] + .mwform-radio-field-text {
    margin: 0;
    padding: 10px 5px 12px 23px;
  }
  input[type=radio] + .mwform-radio-field-text::before {
    height: 15px;
    width: 15px;
  }
  input[type=radio] + .mwform-radio-field-text::after {
    content: "";
    height: 9px;
    left: 3px;
    width: 9px;
  }
  input[type=checkbox] + label {
    padding-left: 30px;
  }
  .l-footer__inner {
    gap: 4.2307692308%;
    grid-template-columns: 1.2fr 2fr 1.02fr;
    padding-block: 4.8rem 2.8rem;
  }
  .l-footer__menu {
    flex-wrap: wrap;
    gap: 1rem 0;
    justify-content: center;
  }
  .l-footer__menu {
    font-size: 1.5rem;
  }
  .l-footer__menu-item:first-child > .l-footer__menu-link {
    border-left: unset;
  }
  .l-footer__menu-item:last-child > .l-footer__menu-link {
    border-right: unset;
  }
  .l-footer__menu-link {
    border-left: unset;
    padding-block: 1rem;
  }
  .l-footer__menu--sub {
    gap: 2rem 5rem;
    margin-top: 5rem;
  }
  .l-footer__menu-item--sub.mr-50 {
    margin-right: unset;
  }
  .l-footer__menu-link--icon {
    margin-left: unset;
  }
  .l-footer__menu-link--icon {
    width: 3.8rem;
  }
  .l-footer__bottom-inner {
    height: 4.4rem;
  }
  .l-main--404 .l-main__inner, .l-main--error .l-main__inner {
    padding: 80px 15px;
  }
  .l-main--404 .c-btn, .l-main--error .c-btn {
    margin-top: 30px;
  }
  .c-heading::before {
    rotate: 20deg;
  }
  .c-grid__ttl--sub {
    font-size: 1.7rem;
  }
  .c-top-list__h3,
  .c-top-list__p {
    letter-spacing: 0.1em;
  }
  .c-top-list__time {
    font-size: 1.4rem;
    width: 10.4rem;
  }
  .p-company__heading-text {
    font-size: 3.8rem;
  }
  .p-company__messege {
    grid-template-columns: 1fr 14rem;
  }
  .p-company__h3 {
    line-height: 1.2;
  }
  .p-company__banner {
    grid-template-rows: repeat(2, 23.8rem);
    margin-top: 4.4rem;
  }
  .p-company__detail {
    margin-top: 6.8rem;
  }
  .p-company__detail-grid {
    grid-template-areas: "g-1 g-2" "g-1 g-3";
    grid-template-columns: 1fr 1fr;
  }
  .p-company__detail-grid > .p-company__banner-3 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid-2 {
    grid-area: g-2;
  }
  .p-company__detail-grid-2 img {
    -o-object-fit: contain;
    object-fit: contain;
  }
  .p-company__detail-grid-3 {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-area: g-3;
  }
  .p-service__container > .p-company__detail-grid-3 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-company__detail-grid-3 img {
    -o-object-fit: contain;
    object-fit: contain;
  }
  .p-archive__h3-container--construction {
    flex-direction: column;
    gap: 1rem;
  }
  .p-archive-construction__tax {
    padding: 0.6rem 0.3rem;
  }
  .p-archive-construction__post {
    padding: 0.6rem 0.6rem;
  }
  .p-archive-construction__time {
    margin-left: 2rem;
  }
  .p-archive-construction__ttl {
    margin-left: 0.8rem;
  }
  .p-single-construction__body {
    width: 100%;
  }
  .p-single-construction__dt {
    font-size: 1.4rem;
  }
  .p-single-construction__dd {
    font-size: 1.4rem;
  }
  .p-single-construction__botton {
    grid-template-columns: 0.3fr 0.9fr 0.29fr;
  }
  .p-contact__grid-heading {
    gap: 2.5rem;
  }
  .p-contact__image-logo {
    margin-inline: auto;
    margin-left: auto;
  }
  .p-contact__tel-container {
    margin-inline: auto;
    margin-left: auto;
    margin-top: 3.4rem;
  }
  .p-contact__tel-text {
    font-size: 2rem;
  }
  .p-contact__mail-container {
    margin-inline: auto;
    margin-left: auto;
  }
  .p-contact__mail-text {
    font-size: 1.5rem;
  }
  .smf-form--business {
    font-size: 1.6rem;
    width: 100%;
  }
  .p-archive__ul {
    padding-left: 4.5rem;
  }
  .p-archive__li-link {
    padding-left: 1.5rem;
  }
  .p-archive__messege {
    padding-left: 6.5rem;
  }
  .p-archive__h4 {
    line-height: 1.2;
  }
  .p-single-info__body {
    padding-right: 0;
  }
  .p-single-info__bottom {
    grid-template-columns: 0.3fr 0.9fr 0.29fr;
    padding-top: 8rem;
  }
  .p-service__heading-text {
    font-size: 3.8rem;
  }
  .p-service__h3 {
    font-size: 3.5rem;
  }
  .p-service__container::after {
    top: 46%;
  }
  .p-service__container {
    gap: 3.1rem 2rem;
    grid-template-rows: 16rem 1fr;
  }
  .p-company__detail-grid-1 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
  }
  .p-company__detail-grid-2 {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid > .p-company__detail-grid-3 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid > .p-single-construction__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-single-info__btn {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
  }
  .p-single-info__messege {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid > .p-single-info__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-service__grid--grid01 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
  }
  .p-service__grid--grid02 {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid > .p-service__grid--grid03 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-service__ul {
    margin-top: 8.2rem;
    padding-left: 0.5rem;
  }
  .p-service__list-number::before {
    right: 54%;
    rotate: 25deg;
    top: -8%;
  }
  .p-service__list-h4 {
    font-size: 3.8rem;
  }
  .p-service__list-description {
    padding-top: 2rem;
  }
  .p-top-service__grid {
    padding: 1.6rem 2rem;
  }
  .p-top-company::after {
    height: 12rem;
    width: 22%;
  }
  .u-pc {
    display: none;
  }
  .u-disp__less1023 {
    display: block !important;
  }
}

@media screen and (max-width: 1000px){
  .p-top-fv__bars01 {
    position: absolute;
    right: 30rem;
    width: 15rem;
  }
  .p-top-fv__bars02 {
    right: 15rem;
    width: 15rem;
    z-index: 50;
  }
  .p-top-fv__bars03 {
    right: 0rem;
    width: 15rem;
  }
}

@media screen and (max-width: 930px){
  p.c-head__catch.loading__text01.is-show {
    font-size: 3.2rem;
  }
}

@media screen and (max-width: 900px){
  .p-top-fv__head p.c-head__catch-bottom {
    font-size: 2rem;
  }
}

@media not all and (max-width: 769px){
  a[href^="tel:"] {
    pointer-events: none;
  }
  .u-pt {
    display: none !important;
  }
}

@media screen and (max-width: 769px){
  :root {
    --header_height: 90px;
  }
  html {
    font-size: 62.5%;
  }
  .l-footer__inner {
    display: block;
    max-width: 50rem;
    padding-block: 2.8rem;
  }
  .l-footer__logo {
    margin-inline: auto;
    width: 50%;
  }
  .l-footer__container-menu {
    padding-top: 3.2rem;
  }
  .l-footer__menu-link {
    padding-inline: 1.3rem;
  }
  .l-footer__menu--sub {
    font-size: 1.2rem;
    gap: 1rem 3rem;
    margin-inline: auto;
    margin-top: 2rem;
    max-width: 30rem;
  }
  .l-footer__container-cta {
    font-size: 1.4rem;
    margin-top: 3.2rem;
  }
  .l-footer__cta-p--2 {
    margin-top: 1.8rem;
  }
  .l-footer__btn.c-cta-btn {
    width: 80%;
  }
  .l-footer__tel a {
    margin-inline: auto;
    margin-top: 1.2rem;
    width: 58%;
  }
  .l-footer__cta-access {
    line-height: 1.3;
    margin-inline: auto;
    text-align: center;
    width: 28rem;
  }
  .l-footer__bottom-inner {
    justify-content: left;
  }
  .l-footer__copyright {
    font-size: 1rem;
  }
  .l-footer__bottom-img {
    width: 30%;
  }
  .l-header__mv--low {
    height: auto;
    min-height: 16.5rem;
  }
  .l-header__mv-low-logo {
    right: 1.75%;
    top: 1.2rem;
    width: 22.8rem;
  }
  .l-header__btn {
    width: 13.4rem;
  }
  .l-header__btn a {
    font-size: 1.6rem;
  }
  .l-header__ul {
    flex-wrap: wrap;
    font-size: 1.5rem;
    gap: 1rem 0;
    justify-content: center;
  }
  .l-header__li:first-child a, .l-header__li:nth-child(4) a {
    border-left: unset;
  }
  .l-header__li a {
    padding-inline: 0.8rem;
  }
  .l-header__logo {
    width: 13rem;
  }
  .l-header__trigger {
    height: 4.8rem;
    width: 6rem;
  }
  .l-header__trigger-line:nth-of-type(3) {
    top: 1rem;
  }
  .l-main--404 h1, .l-main--error h1 {
    width: 80%;
  }
  .l-main--404 .error-text, .l-main--error .error-text {
    font-size: 1.5rem;
  }
  .l-main--404 .error-link, .l-main--error .error-link {
    font-size: 1.5rem;
  }
  .c-grid-columns {
    display: block;
    margin-inline: auto;
    max-width: 65rem;
  }
  .c-heading::before {
    display: none;
  }
  .c-heading {
    width: 16rem;
  }
  .c-heading__ttl {
    letter-spacing: 0.64em;
  }
  .c-heading__p {
    margin-bottom: unset;
    margin-left: 1em;
    margin-right: unset;
    margin-top: unset;
    text-align: left;
  }
  .c-heading__content {
    align-items: center;
    display: flex;
    justify-content: space-between;
  }
  .c-archive {
    margin-top: 2rem;
  }
  .c-top-list__ul {
    padding-top: unset;
  }
  .c-top-list__li a {
    align-items: flex-start;
    flex-direction: column;
  }
  .c-top-list__ttl {
    font-size: 1.6rem;
  }
  .c-cta-btn {
    border-radius: 12px;
    font-size: 2.8rem;
    margin-inline: auto;
  }
  .c-cta-btn a {
    width: 28rem;
  }
  .c-cta-sns {
    width: 2.4rem;
  }
  .c-to-top {
    translate: 0 -5.8rem;
    width: 4rem;
  }
  .p-company__top-body {
    margin-top: -2rem;
  }
  .p-company__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-company__heading-text {
    font-size: 2.8rem;
    padding-left: 0;
    padding-top: 1.2rem;
    text-align: center;
  }
  .p-company__heading-description {
    margin-top: 1.5rem;
    padding: 1.2rem 2.4rem;
  }
  .p-company__messege {
    gap: 1rem;
    grid-template-columns: 1fr;
  }
  .p-company__messege-textarea {
    margin-top: 2.8rem;
  }
  .p-company__h3 {
    font-size: 1.8rem;
    line-height: 1.5;
    margin-top: 1rem;
  }
  .p-company__messege-text {
    margin-top: 2rem;
  }
  .p-company__banner {
    grid-template-rows: repeat(2, 11.8rem);
  }
  .p-company__detail {
    grid-template-columns: 1fr;
  }
  .p-company__detail-logo {
    margin-inline: auto;
    padding-top: 0;
    width: 60%;
  }
  .p-company__detail-wrapper {
    padding-bottom: 2rem;
  }
  .p-company__detail-grid {
    grid-template-areas: "g-1 g-1" "g-2 g-3";
    grid-template-columns: 1fr 1fr;
  }
  .p-company__detail-grid > .p-company__banner-3 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid-1 {
    grid-area: g-1;
  }
  .p-company__detail-p {
    line-height: 1;
  }
  .p-company__detail-adress a[href^="tel:"] {
    pointer-events: auto;
    text-decoration: underline;
  }
  .p-construction__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-archive-construction__tax-container {
    flex-direction: column;
    gap: 0.8rem;
    margin-top: 1.5rem;
  }
  .p-archive-construction__tax-list {
    gap: 1.2rem;
  }
  .p-archive-construction__li-link {
    border-bottom: 1px dotted #9a947e;
    flex-direction: column;
  }
  .p-archive-construction__image {
    margin-inline: auto;
    width: 95%;
  }
  .p-archive-construction__text-container {
    border-bottom: unset;
    display: grid;
    gap: 0.6rem 0;
    grid-template-areas: "g-item-1 g-item-2 ." "g-item-3 .   ." "g-item-4 g-item-4 g-item-4";
    grid-template-columns: 3.82rem 11rem 1fr;
    margin-inline: auto;
    width: 95%;
  }
  .p-archive-construction__tax {
    grid-area: g-item-1;
  }
  .p-archive-construction__post {
    flex-grow: 1;
    grid-area: g-item-2;
  }
  .p-archive-construction__time {
    grid-area: g-item-3;
    margin-left: 0;
    margin-top: 1rem;
  }
  .p-archive-construction__ttl {
    grid-area: g-item-4;
    margin-left: 0;
  }
  .p-archive-construction__tax {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-archive-construction__post {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-archive-construction__time {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-archive-construction__ttl {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 5;
  }
  .p-single-construction__h3 {
    letter-spacing: 0;
    padding-bottom: 1.2rem;
  }
  .p-single-construction__container {
    margin-top: 2.2rem;
  }
  .p-single-construction__dl-box:nth-child(2) {
    margin-top: 1rem;
  }
  .p-single-construction__dl-box--textarea {
    flex-direction: column;
    gap: 0.8rem;
  }
  .p-single-construction__dl-box--textarea--before {
    flex-direction: column;
    gap: 0.8rem;
  }
  .p-single-construction__image-l {
    margin-top: 1rem;
  }
  .p-single-construction__image-s-container {
    margin-top: 2rem;
    padding-bottom: 1.4rem;
  }
  .p-single-construction__image-s-container--before {
    margin-top: 0;
  }
  .p-single-construction__botton {
    align-items: center;
    gap: 6rem 0;
    grid-template-areas: "g-1 g-3" "g-2 g-2";
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(2, auto);
  }
  .p-single-construction__botton > .p-company__banner-3 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-construction__botton > .p-company__detail-grid-1 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-single-construction__botton > .p-company__detail-grid-2 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-single-construction__botton > .p-company__detail-grid-3 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-construction__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-area: g-3;
    justify-content: center;
    padding-top: 0;
  }
  .p-service__container > .p-single-construction__to-other {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-contact__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-contact__image-logo {
    width: 62%;
  }
  .p-contact__tel-container {
    margin-top: 2.4rem;
    width: unset;
  }
  .p-contact__tel-number a[href^="tel:"] {
    pointer-events: auto;
  }
  .p-contact__tel-number {
    width: 70%;
  }
  .p-contact__tel-time {
    font-size: 1.5rem;
  }
  .p-contact__mail-container {
    margin-top: 4.4rem;
  }
  .p-contact__mail-heading {
    font-size: 1.8rem;
  }
  .p-contact__mail-text {
    font-size: 1.4rem;
    line-height: 1.5;
    margin-top: 1.2rem;
  }
  .smf-form--business .smf-item__col--label {
    border-bottom: unset;
    border-right: 1px solid #6b6b6b;
    padding-left: 1em;
    width: 22rem;
  }
  .smf-form--business .smf-item__col--label::before {
    display: none;
  }
  .smf-first .smf-item__col--label {
    padding-top: 2.5rem;
  }
  .smf-item__col--controls {
    border-left: 1px solid #6b6b6b;
  }
  .smf-radio-buttons-control__control {
    flex-direction: column;
    gap: 1.5rem;
  }
  .smf-radio-buttons-control__control {
    flex-direction: column;
    gap: 1.2rem;
  }
  .smf-control-fieldset > * + * {
    margin-top: 0;
  }
  .p-error {
    margin-top: 0;
    padding-block: 5rem 4rem;
  }
  .p-top-fv__head h2,
  .p-top-fv__head h1 {
    font-size: 7.4rem;
  }
  .p-top-fv__head p.c-head__catch {
    font-size: 3.4rem;
  }
  .p-top-fv__head p.c-head__catch-bottom {
    font-size: 1.6rem;
    padding-left: 0.2rem;
  }
  .p-top-fv__sns-links {
    gap: 2rem;
  }
  .p-top-fv__contact {
    margin-left: auto;
    padding-right: 0;
  }
  .p-top-fv__sns-links.u-pt {
    padding-left: 3rem;
  }
  .p-top-fv__sns-link img {
    width: 4rem;
  }
  p.c-head__catch.loading__text01.is-show {
    font-size: 3rem;
    margin-top: 1.5rem;
    padding-left: 0;
  }
  .p-top-fv__bars-black__shadow {
    height: 100%;
    width: 50%;
  }
  .p-top-fv__bars01-img-in {
    bottom: -13.5rem;
    height: unset;
    left: -17.5rem;
    rotate: -27deg;
    transform: unset;
    width: 111%;
  }
  .p-top-fv__bars01-img-in::before {
    left: -8.4rem;
    rotate: -63deg;
  }
  .p-top-fv__bars02-img-in {
    bottom: -8rem;
    height: unset;
    left: -22rem;
    overflow: hidden;
    rotate: -27deg;
    transform: unset;
    width: 114%;
  }
  .p-top-fv__bars02-img-in::before {
    left: -0.9rem;
    rotate: -63deg;
    top: -6.1rem;
    width: 136%;
  }
  .p-top-fv__bars03-img-in {
    height: unset;
    left: -15.8rem;
    overflow: hidden;
    rotate: -27deg;
    top: 12.3rem;
    transform: unset;
    width: 109%;
  }
  .p-top-fv__bars03-img-in::before {
    left: -34.6rem;
    rotate: -63deg;
    top: -2.5rem;
    transform: unset;
  }
  .p-top-fv__bars01-wrap {
    bottom: 15rem;
    height: 30rem;
    left: 0;
    position: absolute;
    width: 100vw;
    z-index: 110;
  }
  .p-top-fv__bars02-wrap {
    bottom: 4rem;
    height: 30rem;
    left: 0;
    position: absolute;
    width: 100vw;
    z-index: 110;
  }
  .p-top-fv__bars03-wrap {
    bottom: 15rem;
    height: 30rem;
    left: 0;
    position: absolute;
    width: 100vw;
    z-index: 110;
  }
  .p-top-fv__bars01 {
    bottom: -24.5rem;
    height: 317%;
    right: calc(50% - 6rem);
    rotate: 243deg;
    transform: scaleX(-1);
    width: 9rem;
    z-index: 60;
  }
  .p-top-fv__bars02 {
    bottom: -23.6rem;
    height: 317%;
    right: calc(50% - 6rem);
    rotate: 243deg;
    transform: scaleX(-1);
    width: 9rem;
    z-index: 60;
  }
  .p-top-fv__bars03 {
    bottom: -44.7rem;
    height: 317%;
    right: calc(50% - 6rem);
    rotate: 243deg;
    transform: scaleX(-1);
    width: 9rem;
    z-index: 60;
  }
  .p-top-fv__bars-black {
    height: 100%;
    left: 21rem;
    rotate: 39deg;
    top: -32rem;
    width: 100%;
    width: 17rem;
  }
  .p-top-fv__bars01-img {
    bottom: 16.5rem;
    left: -18.8rem;
    transform: scaleY(0);
    transform-origin: top;
    width: 75.5rem;
  }
  .p-top-fv__bars02-img {
    left: -13.3rem;
    top: -4rem;
  }
  .p-top-fv__bars03-img {
    bottom: 20rem;
    left: -15.1rem;
  }
  .p-top-fv__bars01-img.is-animate {
    animation: moveToBottom 0.9s cubic-bezier(0.85, 0, 0.175, 1) forwards;
  }
  .p-top-fv__bars03-img.is-animate {
    animation: moveToBottom 0.9s cubic-bezier(0.85, 0, 0.175, 1) forwards;
  }
  .p-top-fv__bars02 img.p-top-fv__bars-text {
    left: 16.1rem;
    position: absolute;
    top: unset;
    transform: unset;
    -o-object-fit: contain;
    bottom: -51rem;
    height: 140%;
    object-fit: contain;
    opacity: 0;
    rotate: 206deg;
    top: unset;
    transform: scaleX(-1);
    width: 7.4rem;
  }
  .p-archive-info__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-archive__ul {
    padding-left: 0;
  }
  .p-archive__h3 {
    font-size: 2.2rem;
  }
  .p-archive__li {
    margin-top: 0;
  }
  .p-archive__li-link {
    align-items: flex-start;
    flex-direction: column;
    gap: 1rem;
    padding-left: 0;
  }
  .p-archive__messege {
    margin-inline: auto;
    margin-top: 9rem;
    padding-left: 0;
  }
  .p-archive__massege-text {
    margin-inline: auto;
    max-width: 65rem;
    padding-inline: 2rem;
    text-align: left;
  }
  .p-single-info__container {
    margin-top: 2.7rem;
  }
  .p-single-info__heading {
    align-items: flex-start;
    flex-direction: column;
    gap: 1rem;
  }
  .p-single-info__h3 {
    text-align: center;
  }
  .p-single-info__h4 {
    line-height: 1.5;
  }
  .p-single-info__content {
    padding-left: 0;
  }
  .p-single-info__bottom {
    align-items: center;
    gap: 6rem 0;
    grid-template-areas: "g-1 g-3" "g-2 g-2";
    grid-template-columns: 1fr 1fr;
    grid-template-rows: repeat(2, auto);
    padding-top: 4rem;
  }
  .p-single-info__bottom > .p-company__banner-3 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-info__bottom > .p-company__detail-grid-1 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-single-info__bottom > .p-company__detail-grid-2 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-single-info__bottom > .p-company__detail-grid-3 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-info__bottom > .p-single-construction__to-other {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-info__btn {
    grid-area: g-1;
    margin-inline: auto;
  }
  .p-single-info__messege {
    grid-area: g-2;
  }
  .p-single-info__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    grid-area: g-3;
    justify-content: center;
    padding-top: 0;
  }
  .p-service__container > .p-single-info__to-other {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-policy {
    margin-top: 0;
    padding-block: 2rem 4rem;
  }
  .p-service__top-body {
    margin-top: -2rem;
  }
  .p-service__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-service__heading-text {
    font-size: 2.8rem;
    padding-left: 0;
    padding-top: 1.2rem;
    text-align: center;
  }
  .p-service__heading-description {
    margin-top: 1.5rem;
  }
  .p-service__image-container {
    clip-path: polygon(5% 0, 100% 0%, 95% 100%, 0% 100%);
    display: grid;
    grid-template-columns: 1fr 1fr;
    height: 4rem;
    overflow: hidden;
    padding-top: 0;
    width: 80%;
  }
  .p-service__h3 {
    font-size: 2.8rem;
  }
  .p-service__heading-en {
    height: 1.6rem;
    padding-right: 1.2rem;
  }
  .p-service__heading-en::before {
    height: 2.2rem;
    width: 0.8rem;
  }
  .p-service__body {
    margin-top: 1rem;
  }
  .p-service__container::after {
    display: none;
  }
  .p-service__container {
    gap: 3.2rem;
    grid-template-areas: "g-1" "g-3" "g-2" "g-4";
    grid-template-columns: 1fr;
    grid-template-rows: unset;
    margin-top: 2rem;
    padding: 2.2rem 2.8rem 0.8rem;
  }
  .p-service__container > .p-company__banner-3 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-service__container > .p-company__banner-4 {
    -ms-grid-row: 7;
    -ms-grid-column: 1;
  }
  .p-service__container > .p-company__detail-grid-1 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-service__container > .p-company__detail-grid-2 {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-service__container > .p-company__detail-grid-3 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-service__container > .p-single-construction__to-other {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-service__container > .p-single-info__btn {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-service__container > .p-single-info__messege {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-service__container > .p-single-info__to-other {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-service__grid--grid03 {
    position: relative;
  }
  .p-service__grid--grid03::before {
    bottom: -0.8rem;
    content: "";
    display: block;
    left: -2.8rem;
    position: absolute;
    right: -2.8rem;
    top: -1.4rem;
    z-index: -1;
  }
  .p-company__detail-grid > .p-company__detail-grid-1 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .p-company__detail-grid > .p-company__detail-grid-2 {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-company__detail-grid > .p-company__detail-grid-3 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-company__detail-grid > .p-single-construction__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-single-construction__botton > .p-single-construction__to-other {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-company__detail-grid > .p-single-info__btn {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .p-single-construction__botton > .p-single-info__btn {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-single-info__bottom > .p-single-info__btn {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-company__detail-grid > .p-single-info__messege {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-single-construction__botton > .p-single-info__messege {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-single-info__bottom > .p-single-info__messege {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-company__detail-grid > .p-single-info__to-other {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-single-construction__botton > .p-single-info__to-other {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-info__bottom > .p-single-info__to-other {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-company__detail-grid > .p-service__grid--grid01 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .p-single-construction__botton > .p-service__grid--grid01 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-single-info__bottom > .p-service__grid--grid01 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-service__container > .p-service__grid--grid01 {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-company__detail-grid > .p-service__grid--grid02 {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
  }
  .p-single-construction__botton > .p-service__grid--grid02 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-single-info__bottom > .p-service__grid--grid02 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .p-service__container > .p-service__grid--grid02 {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-company__detail-grid > .p-service__grid--grid03 {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-single-construction__botton > .p-service__grid--grid03 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-single-info__bottom > .p-service__grid--grid03 {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-service__container > .p-service__grid--grid03 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-service__container > .p-service__grid--grid04 {
    -ms-grid-row: 7;
    -ms-grid-column: 1;
  }
  .p-service__grid--grid04 {
    position: relative;
  }
  .p-service__grid--grid04::before {
    bottom: -0.8rem;
    content: "";
    display: block;
    left: -2.8rem;
    position: absolute;
    right: -2.8rem;
    top: -1rem;
    z-index: -1;
  }
  .p-service__grid-h4 {
    font-size: 1.8rem;
  }
  .p-service__grid-electric {
    margin-top: 3.4rem;
  }
  .p-service__ul {
    margin-top: 2.6rem;
  }
  .p-service__list-number {
    aspect-ratio: 1/1.1;
    padding-top: 2.5rem;
    width: 8rem;
  }
  .p-service__list-number--2 {
    margin-left: 0;
  }
  .p-service__list-number img {
    height: 73%;
    padding-bottom: 0;
    padding-top: 0.8rem;
  }
  .p-service__list-number::before {
    display: block;
    right: 24%;
    rotate: 31deg;
    top: -41%;
  }
  .p-service__list-h4 {
    font-size: 2.4rem;
    margin-top: 0.8rem;
  }
  .p-service__list-box {
    grid-template-areas: "g-5 g-5" ". g-6";
    grid-template-columns: 1fr 30.3rem;
    grid-template-rows: 1fr 15rem;
  }
  .p-service__list-description {
    grid-area: g-5;
    padding-block: 1rem;
    padding-inline: 1rem;
  }
  .p-service__list-image {
    grid-area: g-6;
  }
  .p-service__list-description {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
  }
  .p-service__list-image {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .p-service__list-image--1 img {
    object-view-box: inset(0px 47px 560px 20px);
  }
  .p-service__list-image--2 img {
    object-view-box: inset(110px 160px 530px 20px);
  }
  .p-service__messege {
    padding-left: 0;
    padding-left: 0;
  }
  .p-site_map {
    margin-top: 0;
    padding-block: 2rem 4rem;
  }
  .p-site_map__grid {
    gap: 1.5rem 1.2rem;
    grid-template-columns: repeat(2, 1fr);
    padding-inline: 1rem;
  }
  .p-top {
    padding-bottom: 12rem;
  }
  .p-top-service__heading {
    align-items: center;
    display: flex;
    width: auto;
  }
  .p-top-service__body {
    display: block;
  }
  .p-top-service__grid--yellow {
    margin-top: 2.6rem;
  }
  .p-top-info {
    margin-top: 5.2rem;
  }
  .p-top-company::after {
    height: 10rem;
  }
  .p-top-company {
    height: 25.4rem;
  }
  .p-top-campany__heading::after {
    display: none;
  }
  .p-top-campany__ttl {
    font-size: 3.9rem;
  }
  .p-top-company__heading-p {
    box-shadow: unset;
  }
  .p-top-campany__svg {
    width: 3.5rem;
  }
  .u-sp {
    display: none !important;
  }
  .u-pb-wide {
    padding-bottom: 8rem;
  }
  .u-padding-top {
    padding-top: 2.8rem;
  }
}

@media screen and (max-width: 768px){
  h1.p-top-fv__logo {
    left: 3rem;
    width: 23rem;
  }
}

@media screen and (max-width: 767px){
  .pc-only-inline {
    display: none;
  }
  .sp-only-inline {
    display: inline;
  }
}

@media (max-width: 640px){
  .smf-form--business .smf-item__col--label {
    width: unset;
  }
}

@media (max-width: 639px){
  .smf-item__col--controls {
    border-top: unset;
    padding: 1.6rem !important;
  }
}

@media screen and (max-width: 600px){
  .p-top-fv__bars01-img-in {
    bottom: -6.3rem;
    bottom: 0.5rem;
    left: -5.3rem;
    left: -5rem;
    overflow: hidden;
    rotate: -27deg;
    transform: unset;
    width: 80%;
  }
  .p-top-fv__bars01-img-in::before {
    left: -0.1rem;
  }
  .p-top-fv__bars02-img-in::before {
    left: -1.3rem;
  }
}

@media screen and (max-width: 500px){
  .p-top-fv__bars03-img-in {
    bottom: -5.3rem;
    left: -5.3rem;
    left: 3rem;
    overflow: hidden;
    rotate: -27deg;
    top: -7rem;
    transform: unset;
    width: 65%;
  }
  .p-top-fv__bars03-img-in::before {
    left: -29.7rem;
    top: 2.7rem;
  }
}

@media screen and (max-width: 490px){
  .p-top-fv__bars02-img-in {
    bottom: -24rem;
    left: -5.7rem;
    overflow: hidden;
    rotate: -27deg;
    transform: unset;
    width: 68%;
  }
  .p-top-fv__bars02 img.p-top-fv__bars-text {
    left: 16.1rem;
    position: absolute;
    top: unset;
    transform: unset;
    -o-object-fit: contain;
    bottom: -52rem;
    height: 140%;
    object-fit: contain;
    opacity: 0;
    rotate: 206deg;
    top: unset;
    transform: scaleX(-1);
    width: 7.4rem;
  }
}

@media screen and (max-width: 480px){
  h1.p-top-fv__logo {
    left: 2rem;
  }
  .p-top-fv__head h2,
  .p-top-fv__head h1 {
    font-size: 4rem;
  }
  .p-top-fv__head p.c-head__catch-bottom {
    font-size: 1rem;
    font-size: 1rem;
    letter-spacing: 0.12em;
    letter-spacing: 0.12em;
    line-height: 1.6;
    margin-top: 0.4rem;
    margin-top: 0.4rem;
  }
  .p-top-fv__sns-links {
    gap: 1rem;
  }
  p.c-head__catch.loading__text01.is-show {
    font-size: 2rem;
    padding-left: 0;
  }
  .p-top-fv__bars-black {
    left: 6rem;
    top: -22rem;
  }
}

@media (hover: hover) and (pointer: fine){
  .l-footer__logo-link:hover {
    opacity: 0.7;
  }
  .l-footer__menu-link:hover::before {
    width: calc(100% - 2rem);
  }
  .l-footer__menu-link--sub:hover {
    color: #fff;
  }
  .l-footer__menu-link--icon:hover {
    opacity: 0.7;
  }
  .l-footer__btn:hover a {
    background-color: #fff;
    border-radius: 7px;
    color: #535f5f;
  }
  .l-header__mv-low-logo:hover a {
    opacity: 0.7;
  }
  .l-header__btn a:hover {
    background-color: #fff;
    border-radius: 7px;
    color: #535f5f;
  }
  .l-header__link-to-top:hover {
    opacity: 0.7;
  }
  .l-header__li a:hover::before {
    width: calc(100% - 2rem);
  }
  .l-main--404 .error-link::after, .l-main--error .error-link::after {
    transition: 0.5s;
    transition-property: left;
  }
  .l-main--404 .error-link:hover::after, .l-main--error .error-link:hover::after {
    left: 1rem;
  }
  .c-top-list__link:hover {
    background-color: #9a947e;
    color: #fff;
  }
  .c-top-list__link:hover .cls-1 {
    fill: #fff;
  }
  .c-top-list__link:hover .cls-2 {
    opacity: 1;
  }
  .c-top-list__li a:hover {
    opacity: 0.6;
  }
  .c-cta-sns:hover a {
    opacity: 0.7;
  }
  .p-company__detail-adress a:hover {
    border-bottom: 1px solid;
    color: #9a947e;
  }
  .p-archive-construction__tax-link:hover {
    opacity: 0.7;
  }
  .p-archive-construction__li-link:hover {
    opacity: 0.7;
  }
  .p-single-construction__to-other:hover a {
    color: #535f5f;
  }
  .smf-radio-buttons-control__control:hover {
    opacity: 0.7;
  }
  .smf-button-control__control:hover {
    background-color: #9a947e !important;
    color: #fff !important;
  }
  h1.p-top-fv__logo:hover {
    opacity: 0.7;
  }
  .p-top-fv__sns-links a:hover {
    opacity: 0.7;
  }
  a.p-top-fv__contact-link:hover {
    background-color: #fff;
    color: #535F5F;
  }
  .p-archive__li-link:hover {
    opacity: 0.7;
  }
  .p-single-info__btn a:hover {
    background-color: #9a947e;
    color: #fff;
  }
  .p-single-info__btn a:hover .cls-1 {
    fill: #fff;
  }
  .p-single-info__to-other:hover a {
    color: #535f5f;
  }
  .p-site_map__box a:hover {
    background-color: #9a947e;
    color: #fff;
  }
}

@media all and (-ms-high-contrast: none){
  html,
  body {
    display: none;
  }
}
/*# sourceMappingURL=maps/style.css.map */
