@charset "UTF-8";
/* ---------------------------         ボタン用          -------------------------------*/
/*------------------- ここから以下の共通 -------------------*/
@import url(https://fonts.googleapis.com/css?family=Open+Sans);
@import url("https://use.fontawesome.com/releases/v5.13.0/css/all.css");
/* =========================================
   Unified Color Scheme (HEX Only)
   Fix: Removed oklch to prevent SCSS compilation errors
   ========================================= */
.custom-btn, .custom-btn--vm {
  width: 80%;
  height: 40px;
  padding: 10px 25px;
  border: 2px solid #09c5bd;
  font-family: "Lato", sans-serif;
  font-weight: 500;
  font-size: 14px;
  background: transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  display: inline-block;
}
.custom-btn--w100 {
  width: 100%;
  height: 96px;
  padding: 10px 25px;
  border: 2px solid #09c5bd;
  font-family: "Lato", sans-serif;
  font-weight: 500;
  font-size: 24px;
  background: transparent;
  cursor: pointer;
  transition: all 0.3s ease;
  position: relative;
  display: inline-block;
  margin-bottom: 96px;
}
.custom-btn--vm {
  border: 1px solid #000000;
}

/*------------------- ここまで以下の共通 -------------------*/
.btn-5 {
  background: #e8a02b;
  color: #fff;
  line-height: 42px;
  padding: 0;
  border: none !important;
}
.btn-5:hover {
  background: transparent;
  color: #e8a02b;
  box-shadow: -7px -7px 20px 0px rgba(255, 255, 255, 0.6), -4px -4px 5px 0px rgba(255, 255, 255, 0.6), 7px 7px 20px 0px rgba(0, 0, 0, 0.1333333333), 4px 4px 5px 0px rgba(0, 0, 0, 0.0666666667);
}
.btn-5:hover:before, .btn-5:hover:after {
  width: 100%;
  transition: 800ms ease all;
}
.btn-5:before, .btn-5:after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  height: 2px;
  width: 0;
  background: #e8a02b;
  transition: 400ms ease all;
}
.btn-5:after {
  right: inherit;
  top: inherit;
  left: 0;
  bottom: 0;
}

.btn-6 {
  background: #90c31f;
  color: #fff;
  line-height: 42px;
  padding: 0;
  border: none;
}
.btn-6 span {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.btn-6 span:before, .btn-6 span:after {
  position: absolute;
  content: "";
  background: #90c31f;
}
.btn-6 span:before {
  left: 0;
  top: 0;
  width: 0%;
  height: 2px;
  transition: all 500ms ease;
}
.btn-6 span:after {
  right: 0;
  bottom: 0;
  width: 0%;
  height: 2px;
  transition: all 500ms ease;
}
.btn-6 span:hover:before {
  width: 100%;
}
.btn-6 span:hover:after {
  width: 100%;
}
.btn-6:before, .btn-6:after {
  position: absolute;
  content: "";
  height: 0%;
  width: 2px;
  background: #90c31f;
}
.btn-6:before {
  right: 0;
  top: 0;
  transition: all 500ms ease;
}
.btn-6:after {
  left: 0;
  bottom: 0;
  transition: all 500ms ease;
}
.btn-6:hover {
  color: #90c31f;
  background: transparent;
}
.btn-6:hover:before {
  transition: all 500ms ease;
  height: 100%;
}
.btn-6:hover:after {
  transition: all 500ms ease;
  height: 100%;
}

/* リフォーム資材の価格改定のお知らせ */
.btn-7 {
  background: #0ea5e9;
  color: #fff;
  line-height: 42px;
  padding: 0;
  border: none;
  z-index: 1;
  transition: all 0.3s linear;
}
.btn-7:hover {
  background: transparent;
  color: #0284c7;
}
.btn-7:hover:before, .btn-7:hover:after {
  height: 0;
  background-color: #0ea5e9;
}
.btn-7:before, .btn-7:after {
  position: absolute;
  content: "";
  left: 0;
  width: 100%;
  height: 50%;
  right: 0;
  z-index: -1;
  background: #0ea5e9;
  transition: all 0.3s ease;
}
.btn-7:before {
  top: 0;
}
.btn-7:after {
  bottom: 0;
}

/*------------------- ここから以下の共通 -------------------*/
*,
*:before,
*:after {
  box-sizing: inherit;
}

html {
  box-sizing: border-box;
  font-size: 62.5%; /*rem算出をしやすくするために*/
}

.btn,
a.btn,
button.btn {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  display: inline-block;
  padding: 1rem 4rem !important;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  transition: all 0.3s;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  letter-spacing: 0.1em;
  color: #212529;
  border-radius: 0.5rem;
}

/*------------------- ここまで以下の共通 -------------------*/
/* ペットと暮らす快適リフォーム */
a.btn-flat {
  overflow: hidden;
  padding: 1.5rem 6rem !important;
  color: #fff !important;
  border-radius: 0 !important;
  background: #751485;
}
a.btn-flat span {
  position: relative;
}
a.btn-flat:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100px;
  height: 100px;
  content: "";
  transition: all 0.5s ease-in-out;
  transform: translateX(-80%) translateY(-25px);
  border-radius: 50%;
  background: #b47abd;
}
a.btn-flat:hover:before {
  width: 400px;
  height: 400px;
  transform: translateX(-1%) translateY(-175px);
}

/* リフォーム資材の価格改定のお知らせ */
.btn-wrap {
  margin: 30px 0;
}

a.btn-c {
  font-size: 2.2rem;
  position: relative;
  padding: 0.25rem 2rem 1.5rem 3.5rem;
  color: #fff;
  background: #09c5bd;
  box-shadow: 0 5px 0 #4aaca8;
}
a.btn-c span {
  font-size: 1.5rem;
  position: absolute;
  top: -10px;
  left: calc(50% - 150px);
  display: block;
  width: 300px;
  padding: 0.2rem 0;
  color: #09c5bd;
  border: 2px solid #09c5bd;
  border-radius: 0.5rem;
  background: #fff;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
}
a.btn-c:hover {
  transform: translate(0, 3px);
  color: #fff;
  background: #51bdb8;
  box-shadow: 0 2px 0 #4aaca8;
}
a.btn-c:hover:before {
  left: 2rem;
}

/* ------------------------   矢印が動くボタン　--------------------------------*/
.btnarrow4 {
  position: relative;
  display: inline-block;
  padding: 0 20px;
  color: #333;
  text-decoration: none;
  outline: none;
}
.btnarrow4::before {
  content: "";
  position: absolute;
  bottom: -8px;
  left: 15%;
  width: 85%;
  height: 1px;
  background: #333;
  transition: all 0.3s;
}
.btnarrow4::after {
  content: "";
  position: absolute;
  bottom: -3px;
  right: 0;
  width: 15px;
  height: 1px;
  background: #333;
  transform: rotate(35deg);
  transition: all 0.3s;
}
.btnarrow4:hover::before {
  left: 40%;
}
.btnarrow4:hover::after {
  right: -25%;
}

/* ------------------------   波打つボタン　--------------------------------*/
.waveBtn {
  width: 200px;
  padding: 20px 30px;
  position: relative;
  display: block;
  text-decoration: none;
  overflow: hidden;
}
.waveBtn:hover .wave {
  top: -120px;
}
.waveBtn span {
  position: relative;
  z-index: 1;
  color: white;
  font-size: 15px;
  letter-spacing: 8px;
}
.waveBtn .wave {
  width: 200px;
  height: 200px;
  background-color: #444857;
  box-shadow: inset 0 0 50px rgba(0, 0, 0, 0.5);
  position: absolute;
  left: 0;
  top: -80px;
  transition: 0.4s;
}
.waveBtn .wave::before, .waveBtn .wave::after {
  width: 200%;
  height: 200%;
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -75%);
}
.waveBtn .wave::before {
  border-radius: 45%;
  background-color: rgb(20, 20, 20);
  -webkit-animation: wave 5s linear infinite;
          animation: wave 5s linear infinite;
}
.waveBtn .wave::after {
  border-radius: 40%;
  background-color: rgba(20, 20, 20, 0.5);
  -webkit-animation: wave 10s linear infinite;
          animation: wave 10s linear infinite;
}

@-webkit-keyframes wave {
  0% {
    transform: translate(-50%, -75%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -75%) rotate(360deg);
  }
}

@keyframes wave {
  0% {
    transform: translate(-50%, -75%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -75%) rotate(360deg);
  }
}
/* ----------------------------------------------------------------------------------------*/
.button-border {
  border: 1px solid #eee;
  padding: 10px 40px;
  position: relative;
  display: inline-block;
  color: #000000;
  text-decoration: none;
  background-color: #eeeeee;
}

/* Effect1
 *************************************** */
/* 擬似要素の共通スタイル */
.button-border::after, .button-border::before {
  background-color: #09c5bd;
  content: "";
  display: block;
  position: absolute;
  z-index: 10;
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
}
.button-border span::after, .button-border span::before {
  background-color: #09c5bd;
  content: "";
  display: block;
  position: absolute;
  z-index: 10;
  transition: all 0.3s ease;
  -webkit-transition: all 0.3s ease;
}
.button-border span::after {
  width: 1px;
  height: 0px;
  left: -1px;
  bottom: -1px;
}
.button-border span::before {
  width: 1px;
  height: 0px;
  top: -1px;
  right: -1px;
}
.button-border::after {
  width: 0px;
  height: 1px;
  top: -1px;
  left: -1px;
}
.button-border::before {
  width: 0px;
  height: 1px;
  right: -1px;
  bottom: -1px;
}
.button-border:hover {
  background-color: #ffffff;
}
.button-border:hover::after, .button-border:hover::before {
  width: 100%;
  width: calc(100% + 1px);
}
.button-border:hover span::after, .button-border:hover span::before {
  height: 100%;
  height: calc(100% + 1px);
}

/* -----------------------------------------------------------------*/
.basicBox {
  width: 130px;
  height: 45px;
  color: #000000;
  font-family: "Open Sans", sans-serif;
  font-size: 1.15rem;
  line-height: 45px;
  text-transform: uppercase;
  text-align: center;
  position: relative;
  cursor: pointer;
}
.basicBox svg {
  position: absolute;
  top: 0;
  left: 0;
}
.basicBox svg rect {
  fill: none;
  stroke: #cccccc;
  stroke-width: 1;
  stroke-dasharray: 400, 0;
  -webkit-transition: all 0.8s ease-in-out;
  -moz-transition: all 0.8s ease-in-out;
  -ms-transition: all 0.8s ease-in-out;
  -o-transition: all 0.8s ease-in-out;
}
.basicBox:hover {
  color: #0284c7;
}
.basicBox:hover svg rect {
  stroke: #0284c7;
  stroke-width: 3;
  stroke-dasharray: 35, 225;
  stroke-dashoffset: 38;
  -webkit-transition: all 0.8s ease-in-out;
  -moz-transition: all 0.8s ease-in-out;
  -ms-transition: all 0.8s ease-in-out;
  -o-transition: all 0.8s ease-in-out;
}

/* -----------------------------------------------------------------*/
/* 年末年始 */
.button01 {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  background: linear-gradient(135deg, #0ea5e9 0%, #0284c7 50%, #0369a1 100%);
  color: white !important;
  font-size: clamp(1.4rem, 2.2vw, 1.6rem);
  font-weight: 500;
  text-decoration: none;
  padding: 1.6rem 3.5rem;
  border-radius: 50px;
  box-shadow: 0 8px 25px rgba(14, 165, 233, 0.3);
  transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
}
@media (max-width: 770px) {
  .button01 {
    width: 100%;
    justify-content: center;
    padding: 1.5rem 2.5rem;
  }
}
.button01:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 35px rgba(14, 165, 233, 0.4);
  text-decoration: none !important;
}
.button01:hover i {
  transform: translateX(4px);
}
.button01 i {
  font-size: 1.3em;
  transition: transform 0.3s ease-out;
}

/* --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
/* --------------------------------------------------  汎用  ------------------------------------------------------------------------------- */
.sectionTitle01 {
  font-size: 2em !important;
  color: #0284c7;
  position: relative;
  display: inline-block;
  margin-bottom: 40px !important;
  padding-bottom: 10px !important;
}
.sectionTitle01::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 3px;
  background-color: #ef4444;
}
@media (max-width: 770px) {
  .sectionTitle01 {
    font-size: 1.5em !important;
  }
}

.sectionContainer {
  max-width: 1250px;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 770px) {
  .sectionContainer {
    padding: 0;
  }
}

.rating {
  margin-top: 5px;
}
.rating i {
  color: #fef2f2;
}

/* --------------------------------------------------  ヒーロー  ------------------------------------------------------------------------------- */
.hero {
  background-color: #f0f9ff;
  padding: 0 0 60px;
  text-align: center;
}
@media (max-width: 770px) {
  .hero {
    padding: 0 24px;
  }
}

.badgeContainer {
  display: flex;
  justify-content: center;
  gap: 25px;
  margin: 40px 0;
  flex-wrap: wrap;
}
.badgeContainer__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background-color: #ffffff;
  padding: 25px 20px;
  border-radius: 12px;
  width: 264px;
  box-shadow: 0 8px 20px rgba(45, 138, 134, 0.1);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.badgeContainer__item i {
  font-size: 3.5rem;
  color: #ef4444;
  margin-bottom: 15px;
  transition: all 0.3s ease;
  background: linear-gradient(135deg, #ef4444, #fef2f2);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  filter: drop-shadow(0 2px 2px rgba(200, 125, 30, 0.2));
}
.badgeContainer__item:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 25px rgba(45, 138, 134, 0.15);
  color: #0ea5e9;
}
.badgeContainer__item:hover i {
  transform: scale(1.1);
}
.badgeContainer__item:hover::before {
  width: 100%;
  opacity: 0.08;
}
.badgeContainer__item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  background-color: #ef4444;
  transition: all 0.3s ease;
  z-index: -1;
}
.badgeContainer__text {
  font-weight: bold;
  color: #0284c7;
  margin-top: 5px;
  transition: all 0.3s ease;
  color: #0ea5e9;
}
.badgeContainer__text--2nd {
  color: #222222;
  margin-top: 5px;
  font-weight: normal;
}

.lpctaButton01 {
  display: inline-block;
  background-color: #ef4444;
  color: #ffffff !important;
  padding: 15px 30px;
  border-radius: 50px;
  font-weight: bold;
  margin-top: 30px;
  transition: all 0.3s ease;
  box-shadow: 0 4px 10px rgba(232, 160, 43, 0.3);
}
.lpctaButton01:hover {
  background-color: #fef2f2;
  transform: translateY(-3px);
  color: #ffffff;
}
.lpctaButton01 i {
  margin-right: 8px;
}

/* --------------------------------------------------  問題提起  ------------------------------------------------------------------------------- */
.ploblemSection {
  background-color: #ffffff;
  text-align: center;
  padding: 60px 0;
}

.ploblemList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 30px;
  margin-top: 40px;
  text-decoration: none;
}
@media (max-width: 770px) {
  .ploblemList {
    grid-template-columns: 1fr;
  }
}
.ploblemList li {
  background-color: #f0f9ff;
  padding: 30px;
  border-radius: 8px;
  text-align: left;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
  position: relative;
  overflow: hidden;
}
@media (max-width: 770px) {
  .ploblemList li {
    margin: 0 20px 0 0;
  }
}
.ploblemList li i {
  font-size: 3.5rem;
  color: #ef4444;
  margin-bottom: 15px;
  display: block;
}
.ploblemList__title {
  font-size: 1.4em !important;
  color: #0284c7;
  margin-bottom: 10px !important;
}

/* --------------------------------------------------  解決策  ------------------------------------------------------------------------------- */
.solutionSection {
  background-color: #fffbf7;
  padding: 60px 20px;
  margin: 0 auto;
}

.solutionList {
  margin-top: 40px;
}
.solutionList__item {
  display: flex;
  margin-bottom: 40px;
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}
@media (max-width: 770px) {
  .solutionList__item {
    flex-direction: column;
  }
}
.solutionList__itemTitle {
  color: #0284c7;
  margin-bottom: 10px !important;
  font-size: 1.4em !important;
  border-left: 4px solid #ef4444;
  padding-left: 10px !important;
}
.solutionList__item div {
  padding: 30px;
}
.solutionList i {
  background-color: #0ea5e9;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 100px;
  font-size: 3.5rem;
}
@media (max-width: 770px) {
  .solutionList i {
    min-width: auto;
    padding: 20px;
  }
}

/* --------------------------------------------------  サービス  ------------------------------------------------------------------------------- */
.serviceSection {
  background-color: #ffffff;
  padding: 60px 20px;
  margin: 0 auto;
}

.serviceList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 30px;
  margin-top: 40px;
  margin-left: 0 !important;
}
@media (max-width: 770px) {
  .serviceList {
    grid-template-columns: 1fr;
  }
}
.serviceList .serviceCard {
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  overflow: hidden;
}
.serviceList .serviceCard__detail {
  padding: 20px;
}
.serviceList .serviceCard__title {
  font-size: 1.3em;
  color: #0284c7;
  margin-bottom: 15px;
  border-bottom: 2px solid #ef4444;
  padding-bottom: 10px;
}
.serviceList .serviceCard__price {
  background-color: #f8fafc;
  padding: 15px;
  border-radius: 8px;
  margin-bottom: 15px;
}
.serviceList .serviceCard__priceRow {
  display: flex;
  justify-content: space-between;
  margin-bottom: 5px;
}
.serviceList .serviceCard__priceLabel {
  font-weight: bold;
  color: #222222;
}
.serviceList .serviceCard__priceValue {
  color: #ef4444;
  font-weight: bold;
}
.serviceList .serviceCard__point {
  display: flex;
  align-items: flex-start;
  margin-top: 15px;
}
.serviceList .serviceCard__point i {
  color: #ef4444;
  margin-right: 10px;
  margin-top: 8px;
}

.otherservice {
  margin-top: 50px;
  background-color: #f0f9ff;
  padding: 30px;
  border-radius: 8px;
}
.otherservice__title {
  color: #0284c7;
  margin-bottom: 20px !important;
  text-align: center;
  font-size: 1.3em !important;
}

.otherserviceList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 20px;
  list-style: none !important;
  margin-left: 0 !important;
}
@media (max-width: 770px) {
  .otherserviceList {
    grid-template-columns: 1fr;
  }
}
.otherserviceList__item {
  background-color: #ffffff;
  padding: 20px;
  border-radius: 8px;
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.05);
}
.otherserviceList__name {
  color: #0284c7;
  margin-bottom: 10px;
  font-weight: bold;
}
.otherserviceList__price {
  color: #ef4444;
  font-weight: bold;
}

.priceNote {
  margin-top: 30px;
  background-color: #f8fafc;
  padding: 15px;
  border-radius: 8px;
  font-size: 1em;
}

/* --------------------------------------------------  お客様の声  ----------------------------------------------------------------------------- */
.voiceSection {
  background-color: #fffbf7;
  padding: 60px 20px;
  margin: 0 auto;
}

.voiceList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
  gap: 30px;
  margin-top: 40px;
  list-style: none !important;
  margin-left: 0 !important;
}
@media (max-width: 770px) {
  .voiceList {
    grid-template-columns: 1fr;
  }
}
.voiceList__item {
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
  position: relative;
  padding: 30px;
}
.voiceList__text {
  position: relative;
  z-index: 1;
  margin-bottom: 20px;
  line-height: 2 !important;
}

.customerInfo {
  display: flex;
  align-items: center;
}
.customerInfo__avatar {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: #e2e8f0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 15px;
  color: #222222;
}
.customerInfo__avatar i {
  font-size: 1.5em;
}
.customerInfo__container {
  line-height: 1.4;
}
.customerInfo__name {
  font-weight: bold;
  color: #0284c7;
  font-size: 1.2em;
}
.customerInfo__meta {
  font-size: 0.9em;
  color: #222222;
}

/* --------------------------------------------------  施工事例  ----------------------------------------------------------------------------- */
.casestudySection {
  background-color: #ffffff;
  padding: 60px 20px;
  margin: 0 auto;
}

.casestudyList {
  margin-top: 40px;
  list-style: none !important;
  margin-left: 0 !important;
}
.casestudyList__item {
  margin-bottom: 50px;
  background-color: #f0f9ff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
}
.casestudyList__images {
  display: flex;
}
@media (max-width: 770px) {
  .casestudyList__images {
    flex-direction: column;
  }
}
.casestudyList__image, .casestudyList__image--after, .casestudyList__image--before {
  flex: 1;
  height: 375px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #222222;
  overflow: hidden;
}
.casestudyList__image--before {
  background-color: #e2e8f0;
}
.casestudyList__image--after {
  background-color: #f8fafc;
}
.casestudyList__imageLabel {
  position: absolute;
  top: 10px;
  left: 10px;
  background-color: rgba(45, 138, 134, 0.8);
  color: #ffffff;
  padding: 5px 15px;
  border-radius: 20px;
  font-size: 1em;
}
.casestudyList__detail {
  padding: 30px;
  font-size: 1.1em;
}
@media (max-width: 770px) {
  .casestudyList__detail {
    line-height: 1.8em;
  }
}
.casestudyList__detailTitle {
  color: #0284c7;
  margin-bottom: 15px !important;
  font-size: 1.2em !important;
}
.casestudyList__detailMeta {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 20px;
}
.casestudyList__detailMetaitem {
  display: flex;
  align-items: center;
  font-size: 1.1em;
}
.casestudyList__detailMetaitem i {
  color: #ef4444;
  margin-right: 5px;
}
.casestudyList__detailMetalabel {
  font-weight: bold;
  margin-right: 5px;
}

/* --------------------------------------------------  流れ  ----------------------------------------------------------------------------- */
.processSection {
  background-color: #f0f9ff;
  padding: 60px 20px;
  margin: 0 auto;
}

.processList {
  margin-top: 40px;
  list-style: none !important;
  margin-left: 0 !important;
}
.processList__item {
  display: flex;
  margin-bottom: 30px;
  position: relative;
}
.processList__item:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 40px;
  top: 80px;
  width: 2px;
  height: calc(100% - 80px);
  background-color: #e2e8f0;
}
@media (max-width: 770px) {
  .processList__item:not(:last-child)::after {
    display: none;
  }
}
@media (max-width: 770px) {
  .processList__item {
    flex-direction: column;
  }
}
.processList__number {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background-color: #0ea5e9;
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2em;
  font-weight: bold;
  margin-right: 30px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
@media (max-width: 770px) {
  .processList__number {
    margin-bottom: 20px;
    margin-right: 0;
  }
}
.processList__content {
  background-color: #ffffff;
  padding: 30px;
  border-radius: 8px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
  flex-grow: 1;
}
.processList__title {
  color: #0284c7;
  margin-bottom: 10px !important;
  font-size: 1.3em !important;
}

/* --------------------------------------------------  お問い合わせ  ----------------------------------------------------------------------------- */
.formSection {
  background-color: #ffffff;
  text-align: center;
  padding: 60px 20px;
  margin: 0 auto;
}
.formSection__message {
  font-size: 1.3em;
  color: #0284c7;
  margin-bottom: 30px !important;
  max-width: 700px;
  margin-left: auto !important;
  margin-right: auto !important;
  line-height: 2 !important;
}
@media (max-width: 770px) {
  .formSection__message {
    font-size: 1.2em !important;
    line-height: 1.8em !important;
  }
}
.formSection .contactForm {
  background-color: #f0f9ff;
  padding: 40px;
  border-radius: 8px;
  margin-top: 50px;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05);
  text-align: left;
}
@media (max-width: 770px) {
  .formSection .contactForm {
    padding: 40px 0;
  }
}
.formSection .contactForm dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  border-bottom: 1px #e5eaf0 solid;
}
@media (max-width: 770px) {
  .formSection .contactForm dl {
    flex-direction: column;
  }
}
.formSection .contactForm dt {
  flex-basis: 30%;
  padding: 10px;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
  color: #222222;
  font-weight: bold;
}
@media (max-width: 770px) {
  .formSection .contactForm dt {
    margin-bottom: 0;
  }
}
.formSection .contactForm dd {
  flex-basis: 65%;
  padding: 10px;
  margin-bottom: 0px !important;
}
@media (max-width: 770px) {
  .formSection .contactForm dd {
    width: 100%;
    padding: 0 0 10px;
  }
}
.formSection .contactForm dd textarea {
  height: 264px;
  border-radius: 10px;
  padding: 12px 14px;
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  border: 1px solid #bac7d6;
  line-height: 1.6;
  box-sizing: border-box;
}
.formSection .contactForm dd textarea::-moz-placeholder {
  color: #cccccc;
}
.formSection .contactForm dd textarea::placeholder {
  color: #cccccc;
}
.formSection .contactForm dd input[type=text],
.formSection .contactForm dd select {
  border-radius: 10px;
  border-radius: 5px;
  background: #ffffff;
  border: 1px solid #bac7d6;
  max-width: 100%;
  box-sizing: border-box;
  vertical-align: middle;
  padding: 12px 14px;
}
.formSection .contactForm dd input::-moz-placeholder {
  color: #cccccc;
}
.formSection .contactForm dd input::placeholder {
  color: #cccccc;
}
.formSection .contactForm dd input[type=text]:focus,
.formSection .contactForm dd textarea:focus {
  border: 2px solid #000000 !important;
  padding: 11px 13px !important;
}
.formSection .contactForm__title {
  color: #0284c7;
  margin-bottom: 20px;
  text-align: center;
  font-size: 1.3em;
}
.formSection .contactForm__required dt:after {
  content: "＊";
  display: inline-block;
  padding: 4px 0px 2px;
  color: #ef4444;
  font-weight: 700;
  margin-left: 4px;
  line-height: 1;
  font-size: 1.3em !important;
}
.formSection .contactForm__item {
  padding: 10px;
}
@media (max-width: 770px) {
  .formSection .contactForm__item {
    padding: 0 10px 10px;
  }
}
.formSection .contactForm__mailConfirm {
  margin-top: 20px;
}
.formSection .contactForm__submit {
  margin-top: 0;
  padding: 0 10px 10px;
  text-align: center;
}
.formSection .contactForm__submitBtn input {
  background-color: #e8a02b;
  color: #ffffff;
  border: none;
  padding: 15px 30px;
  border-radius: 50px;
  font-weight: bold;
  font-size: 1.1em;
  cursor: pointer;
  transition: all 0.3s ease;
  display: block;
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.formSection .contactForm__submitBtn input:hover {
  background-color: #f9b857;
  transform: translateY(-3px);
}
.formSection .contactForm .privacyPolicy {
  margin-top: 15px;
  text-align: center;
  font-size: 1em;
}
.formSection .contactForm .privacyPolicy p {
  line-height: 1.8;
  padding: 0 20px;
}

.menu {
  line-height: 2em;
}
.menu__mainVisual {
  margin: 0 calc(50% - 50vw);
  width: 100vw;
}
.menu__mainVisual img {
  width: 100%;
}
.menu__guide {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  list-style: none !important;
  margin-left: 0 !important;
}
.menu__guide.-mb {
  margin-bottom: 96px;
}
.menu__guide li img {
  transition: all 0.4s ease-in-out;
}
.menu__guide li img:hover {
  box-shadow: 0 0 25px rgba(0, 0, 0, 0.25);
}
.menu .mainToc__intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}
.menu .mainToc__intro.-mb {
  margin-bottom: 48px;
}
.menu .mainToc__intro .introDesc {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.menu .mainToc__intro .introDesc__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  font-weight: 400;
  line-height: 1.6em;
  margin-bottom: 40px;
}
.menu .mainToc__intro .introDesc p {
  line-height: 2em;
}
.menu .mainToc__menu.-mb {
  margin-bottom: 96px;
}
.menu .mainToc__menu .menuTitle {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: auto;
  position: relative;
  padding: 0.8rem 0;
  margin-bottom: 32px;
  border-bottom: 5px solid;
  color: #0284c7;
  font-weight: bold;
  font-size: 26px;
  text-align: center;
}
.menu .mainToc__menu .menuTitle::before, .menu .mainToc__menu .menuTitle::after {
  position: absolute;
  top: 100%;
  left: 50%;
  content: "";
  height: 0;
  width: 0;
}
.menu .mainToc__menu .menuTitle:before {
  border: 16px solid;
  border-color: transparent;
  border-top-color: #0284c7;
  margin-left: -16px;
}
.menu .mainToc__menu .menuTitle:after {
  border: 10px solid;
  border-color: transparent;
  border-top-color: white;
  margin-left: -10px;
}
.menu .mainToc__menu .menuItem {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  list-style: none;
  margin-left: 0 !important;
}
.menu .mainToc__menu .menuItem li {
  display: flex;
  flex-direction: column;
  text-align: center;
  padding: 24px;
}
.menu .mainToc__menu .menuItem li img {
  height: 80px;
}
.menu .mainToc__menu .menuItem li img:hover {
  transform: rotateY(360deg);
}
.menu .mainToc__menu .menuItem li .target {
  transition: 0.5s;
  transform: rotateY(0deg);
}
.menu .catchphrase {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 40px;
  position: relative;
  text-align: initial;
}
.menu .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.menu .catchphrase h3 {
  font-weight: 400;
  margin-bottom: 24px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
}
.menu .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.menu .outlineEach.-mb {
  margin-bottom: 96px;
}
.menu .outlineEach__list {
  list-style: none !important;
  margin-left: 0 !important;
}
.menu .outlineEach__list .listItem {
  margin-bottom: 64px;
}
.menu .outlineEach__list .listItem h4 {
  border-bottom: 1px #000000 solid;
  font-size: 3rem;
  font-weight: normal;
  margin-bottom: 16px;
}
.menu .outlineEach__list .listItem h4 img {
  width: 80px;
}
.menu .outlineEach__list .listItem__cont {
  display: grid;
  grid-template-columns: 30% 1fr;
  gap: 48px;
}
.menu .outlineEach__list .listItem__itemDesc {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.menu .outlineEach__list .listItem__itemDesc ul {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -moz-column-gap: 24px;
       column-gap: 24px;
  list-style: none !important;
  margin-left: 0 !important;
  margin-bottom: 0 !important;
}
.menu .outlineEach__list .listItem__itemDesc ul li::before {
  font-family: "Font Awesome 5 Free";
  content: "\f02b";
  color: #0284c7;
  font-weight: 600;
  margin-right: 4px;
}
.menu .outlineEach__list .listItem__itemDesc .itemDesc__link {
  font-size: 2rem;
}
.menu .outlineEach__list .listItem__itemDesc .itemDesc__link a::before {
  font-family: "Font Awesome 5 Free";
  content: "\f0a4";
  font-size: 32px;
  font-weight: 400;
  margin-right: 4px;
}
.menu .supportArea {
  line-height: 200%;
  text-align: center;
}
.menu .supportArea img {
  width: 600px;
  margin-bottom: 40px;
}
.menu .supportArea__dlBox {
  width: max(45%, 800px);
  margin: 0 auto;
}
.menu .supportArea__dlKyoto {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 0;
}
.menu .supportArea__dlKyoto dt {
  background-color: #0284c7;
  color: #ffffff;
  width: 100px;
}
.menu .supportArea__dlKyoto dd {
  background-color: #ffffff;
  padding: 0 5px;
  margin-bottom: 0;
}
.menu .supportArea__dlShiga {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  flex-direction: row-reverse;
  margin-bottom: 0;
}
.menu .supportArea__dlShiga dt {
  background-color: #ef4444;
  color: #ffffff;
  width: 100px;
}
.menu .supportArea__dlShiga dd {
  background-color: #ffffff;
  padding: 0 5px;
  margin-bottom: 0;
}
.menu .supportArea__cmt {
  font-size: 80%;
  padding: 20px 0;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto;
  text-align: left;
  line-height: 1.8;
}
.menu .supportArea__cmt li {
  list-style: none;
}
.menu .supportArea__cmt li::before {
  content: "※　";
  display: inline-block;
  margin-left: -1.5em;
  width: 1.5em;
}

.reformMenu__mv {
  margin-bottom: 48px;
}
.reformMenu__header {
  margin-bottom: 48px !important;
}
.reformMenu__header .desc {
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.reformMenu__ttl {
  font-size: 40px !important;
  line-height: 200% !important;
  margin: 0 30px 0 0 !important;
  display: inline-block;
  vertical-align: middle;
  font-weight: 100 !important;
  padding: 0 !important;
}
.reformMenu .rfProduct {
  margin-bottom: 120px;
}
.reformMenu .rfProduct__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  list-style: none !important;
  margin-left: 0 !important;
}
.reformMenu .rfProduct__list h4 {
  margin-bottom: 24px;
}
.reformMenu .rfProduct__dlist dt {
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 8px;
  text-align: left;
}
.reformMenu .rfProduct__dlist dd {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 8px;
  line-height: 1.4;
  border-bottom: 1px #cccccc solid;
}
.reformMenu .rfProduct__dlist dd div:nth-child(1) {
  text-align: right;
}
.reformMenu .rfProduct__dlist dd div:nth-child(1)::after {
  content: "～　\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
}
.reformMenu .rfProduct__dlist dd div:nth-child(1)::before {
  content: "定価 ￥";
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) {
  text-align: right;
  color: #0284c7;
  font-weight: bold;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) span:nth-child(1) {
  font-size: 18px;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) span:nth-child(1)::after {
  content: "% OFF";
  font-size: 12px;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) span:nth-child(2) {
  margin-left: 8px;
  font-size: 18px;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) span:nth-child(2)::after {
  content: "～";
  font-size: 1.1rem;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) span:nth-child(2)::before {
  content: "￥";
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) *:nth-child(4) {
  margin-left: 8px;
  color: #000000;
  font-weight: 400;
  font-size: x-small;
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) *:nth-child(4)::after {
  content: "～";
}
.reformMenu .rfProduct__dlist dd div:nth-child(2) *:nth-child(4)::before {
  content: "(税込)￥";
}
.reformMenu .rfProduct__rwItem div:nth-child(1) {
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 8px;
  text-align: left;
}
.reformMenu .rfProduct__rwItem div:nth-child(2) {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-bottom: 8px;
  line-height: 1.4;
  border-bottom: 1px #cccccc solid;
}
.reformMenu .rfProduct__rwItem div:nth-child(2) span:nth-child(odd)::after {
  content: "　\f0da";
  font-family: "Font Awesome 5 Free";
  font-weight: 600;
}
.reformMenu .rfProduct__rwItem div:nth-child(2) span:nth-child(even) {
  text-align: right;
  color: #0284c7;
  font-weight: bold;
  margin-left: 8px;
  font-size: 18px;
}
.reformMenu .rfProduct__rwItem div:nth-child(2) span:nth-child(even)::after {
  content: "～";
  font-size: 1.1rem;
}
.reformMenu .rfProduct__rwItem div:nth-child(2) span:nth-child(even)::before {
  content: "￥";
}
.reformMenu .rfProduct__subTtl {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 64px auto 16px;
  font-size: 24px;
  font-weight: bold;
}
.reformMenu .rfProduct__costDl {
  width: 400px;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto 48px;
}
.reformMenu .rfProduct__costDl dt {
  width: 50%;
  padding: 4px;
  margin-bottom: 4px;
  border-bottom: 1px #0284c7 solid;
  font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
  font-weight: normal;
}
.reformMenu .rfProduct__costDl dd {
  width: 50%;
  text-align: right;
  padding: 4px;
  margin-bottom: 4px;
  border-bottom: 1px #0284c7 solid;
  font-size: clamp(1.6rem, 2.34375vw, 1.8rem);
}
.reformMenu .rfProduct__cmt {
  font-size: 80%;
  padding: 20px 0;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 0 auto;
  text-align: left;
  line-height: 1.8;
}
.reformMenu .rfProduct__cmt li {
  list-style: none;
}
.reformMenu .rfProduct__cmt li::before {
  content: "※　";
  display: inline-block;
  margin-left: -1.5em;
  width: 1.5em;
}

.menuKitchen .layoutArea {
  margin-bottom: 120px;
}
.menuKitchen .layoutArea__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-left: 0 !important;
}
.menuKitchen .layoutArea__list .layoutItem {
  list-style: none;
  padding-bottom: 24px;
}
.menuKitchen .layoutArea__list .layoutItem h4 {
  margin: 24px;
  border-bottom: 1px #0284c7 dotted;
}
.menuKitchen .layoutArea__list .layoutItem__wrap {
  padding: 0 24px;
  overflow: hidden;
}
.menuKitchen .layoutArea__list .layoutItem__wrap p {
  line-height: 1.8;
}
.menuKitchen .layoutArea__list .layoutItem__space {
  float: right;
  height: 5.3em;
}
.menuKitchen .layoutArea__list .layoutItem__i {
  width: 250px;
  float: right;
  clear: both;
  margin: 1.2em 0 0 1.2em;
  line-height: 0;
}
.menuKitchen .layoutArea__desc {
  margin-bottom: 48px !important;
}
.menuKitchen .sizingArea {
  margin-bottom: 120px;
}
.menuKitchen .sizingArea__desc {
  margin-bottom: 48px !important;
}
.menuKitchen .sizingArea__desc img {
  width: 600px;
}
.menuKitchen .sizingArea__wrap {
  display: flex;
}
.menuKitchen .sizingArea__wrap img {
  width: 300px;
}
.menuKitchen .eqArea {
  margin-bottom: 120px;
}
.menuKitchen .eqArea__descWrap {
  display: flex;
  gap: 48px;
  margin-bottom: 96px !important;
}
.menuKitchen .eqArea__descImg {
  width: 100%;
}
.menuKitchen .eqArea__descList {
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-left: 0 !important;
  border: 1px #cccccc solid;
  padding: 24px;
  -moz-column-gap: 16px;
       column-gap: 16px;
}
.menuKitchen .eqArea__descList li {
  border-bottom: 1px #0284c7 dotted;
}
.menuKitchen .eqArea__eqList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.menuKitchen .eqArea__eqList div {
  position: relative;
  padding: 24px;
  background-color: #f8f5f2;
}
.menuKitchen .eqArea__eqList div:before, .menuKitchen .eqArea__eqList div:after {
  content: "";
  width: 20px;
  height: 30px;
  position: absolute;
  display: inline-block;
}
.menuKitchen .eqArea__eqList div:before {
  border-left: solid 2px #666666;
  border-top: solid 2px #666666;
  top: 0;
  left: 0;
}
.menuKitchen .eqArea__eqList div:after {
  border-right: solid 2px #666666;
  border-bottom: solid 2px #666666;
  bottom: 0;
  right: 0;
}
.menuKitchen .eqArea__eqList div dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuKitchen .eqArea__eqList div dt::first-letter {
  font-size: 2em;
  color: #0284c7;
  font-weight: bold;
}

.menuBath .bathszArea {
  margin-bottom: 120px;
}
.menuBath .bathszArea__desc {
  margin-bottom: 48px !important;
}
.menuBath .bathszArea .bathSize {
  display: grid;
  grid-template-columns: 60% calc(40% - 48px);
  gap: 48px;
}
.menuBath .bathszArea .bathSize__desc p {
  margin-bottom: 48px;
}
.menuBath .bathszArea .bathSize__sample {
  list-style: none;
  margin-left: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.menuBath .bathszArea .bathSize__sample li {
  position: relative;
}
.menuBath .bathszArea .bathSize__sample li p {
  position: absolute;
  right: 0;
  bottom: -20px;
}
.menuBath .bathmtArea {
  margin-bottom: 120px;
}
.menuBath .bathmtArea__desc {
  margin-bottom: 48px !important;
}
.menuBath .bathmtArea .bathMaterial {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 48px;
}
.menuBath .bathmtArea .bathMaterial dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuBath .bathmtArea .bathmtTable tr td:not(:first-child) {
  text-align: center;
  width: 16%;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-size: 2rem;
}
.menuBath .bathmtArea .bathmtTable tr td:first-of-type {
  text-align: left;
  width: 20%;
}
.menuBath .bathnwArea__desc {
  margin-bottom: 48px;
}
.menuBath .bathnwArea .bathnwList {
  list-style: none;
  margin-left: 0;
}
.menuBath .bathnwArea .bathnwList h4 {
  margin-bottom: 48px;
}
.menuBath .bathnwArea .bathnwList__desc {
  margin-bottom: 48px;
}
.menuBath .bathnwArea .bathnwList__introR, .menuBath .bathnwArea .bathnwList__introL {
  display: flex;
  gap: 48px;
  margin-bottom: 48px;
  flex-wrap: wrap;
}
.menuBath .bathnwArea .bathnwList__cmt {
  width: 58%;
}
.menuBath .bathnwArea .bathnwList__cmt h5 {
  margin-bottom: 48px;
}
.menuBath .bathnwArea .bathnwList__img {
  width: 38%;
  display: flex;
  align-items: center;
}
.menuBath .bathnwArea .bathnwList iframe {
  width: 100%;
}

.menuToilet .toiletyArea {
  margin-bottom: 120px;
}
.menuToilet .toiletyArea__desc {
  margin-bottom: 48px;
}
.menuToilet .toiletyArea .toileType {
  list-style: none;
  margin-left: 0;
}
.menuToilet .toiletyArea .toileType__listAsc, .menuToilet .toiletyArea .toileType__listDesc {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.menuToilet .toiletyArea .toileType__cont {
  width: 50%;
}
.menuToilet .toiletyArea .toileType__cont h4 {
  margin-bottom: 24px;
  border-bottom: 1px #0284c7 dotted;
}
.menuToilet .toiletyArea .toileType__img {
  width: 40%;
}
.menuToilet .impointArea {
  margin-bottom: 120px;
}
.menuToilet .impointArea__desc {
  margin-bottom: 48px;
}
.menuToilet .impointArea__list {
  list-style: none;
  margin-left: 0;
}
.menuToilet .impointArea__list h4 {
  margin-bottom: 48px;
}
.menuToilet .impointArea__list .drpipeList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
}
.menuToilet .impointArea__list .drpipeList dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 24px;
}
.menuToilet .toilenwArea__desc {
  margin-bottom: 48px;
}
.menuToilet .toilenwArea .toilenwList {
  list-style: none;
  margin-left: 0;
}
.menuToilet .toilenwArea .toilenwList h4 {
  margin-bottom: 48px;
}
.menuToilet .toilenwArea .toilenwList li {
  margin-bottom: 120px;
}
.menuToilet .toilenwArea .toilenwList__desc {
  margin-bottom: 48px;
}
.menuToilet .toilenwArea .toilenwList__introR, .menuToilet .toilenwArea .toilenwList__introL {
  display: flex;
  gap: 48px;
  margin-bottom: 48px;
  flex-wrap: wrap;
  justify-content: space-between;
}
.menuToilet .toilenwArea .toilenwList__cmt {
  width: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.menuToilet .toilenwArea .toilenwList__cmt h5 {
  margin-bottom: 48px;
}
.menuToilet .toilenwArea .toilenwList__img {
  width: 40%;
  display: flex;
  align-items: center;
}
.menuToilet .toilenwArea .toilenwList iframe {
  width: 100%;
}

.menuWashstand .wstandtyArea {
  margin-bottom: 120px;
}
.menuWashstand .wstandtyArea__desc {
  margin-bottom: 48px;
}
.menuWashstand .wstandtyArea__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-left: 0 !important;
  list-style: none;
}
.menuWashstand .wstandtyArea__list .wstandType {
  padding-bottom: 24px;
}
.menuWashstand .wstandtyArea__list .wstandType h4 {
  margin: 24px;
  border-bottom: 1px #0284c7 dotted;
}
.menuWashstand .wstandtyArea__list .wstandType__wrap {
  padding: 0 24px;
  overflow: hidden;
}
.menuWashstand .wstandtyArea__list .wstandType__wrap p {
  line-height: 2;
}
.menuWashstand .wstandtyArea__list .wstandType__space {
  float: right;
  height: 5.3em;
}
.menuWashstand .wstandtyArea__list .wstandType__i {
  width: 250px;
  float: right;
  clear: both;
  margin: 1.2em 0 0 1.2em;
  line-height: 0;
}
.menuWashstand .wstandmiArea {
  margin-bottom: 120px;
}
.menuWashstand .wstandmiArea__desc {
  margin-bottom: 48px;
}
.menuWashstand .wstandmiArea__list {
  list-style: none;
  margin-left: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.menuWashstand .wstandmiArea__list h4 {
  border-bottom: 1px #0284c7 dotted;
  margin-bottom: 24px;
}
.menuWashstand .wstandmiArea__list p {
  line-height: 2;
}
.menuWashstand .wstandnwArea {
  margin-bottom: 120px;
}
.menuWashstand .wstandnwArea .wstandnwDesc {
  display: flex;
  justify-content: space-between;
  margin-bottom: 96px;
}
.menuWashstand .wstandnwArea .wstandnwDesc__cont {
  width: 45%;
  line-height: 2.5;
  display: flex;
  align-items: center;
}
.menuWashstand .wstandnwArea .wstandnwDesc__img {
  width: 50%;
  display: flex;
  align-items: center;
}

.menuroof .materialArea {
  margin-bottom: 120px;
}
.menuroof .materialArea__desc {
  margin-bottom: 48px !important;
}
.menuroof .materialArea__mtList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}
.menuroof .materialArea__mtList div {
  position: relative;
  padding: 24px;
  background-color: #f8f5f2;
}
.menuroof .materialArea__mtList div:before, .menuroof .materialArea__mtList div:after {
  content: "";
  width: 20px;
  height: 30px;
  position: absolute;
  display: inline-block;
}
.menuroof .materialArea__mtList div:before {
  border-left: solid 2px #666666;
  border-top: solid 2px #666666;
  top: 0;
  left: 0;
}
.menuroof .materialArea__mtList div:after {
  border-right: solid 2px #666666;
  border-bottom: solid 2px #666666;
  bottom: 0;
  right: 0;
}
.menuroof .materialArea__mtList div dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuroof .materialArea__mtList div dt::first-letter {
  font-size: 2em;
  color: #0284c7;
  font-weight: bold;
}

.menuOwall .owallmtArea {
  margin-bottom: 120px;
}
.menuOwall .owallmtArea__desc {
  margin-bottom: 48px !important;
}
.menuOwall .owallmtArea__mtList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
  margin-bottom: 48px;
}
.menuOwall .owallmtArea__mtList div {
  position: relative;
  padding: 24px;
  background-color: #f8f5f2;
}
.menuOwall .owallmtArea__mtList div:before, .menuOwall .owallmtArea__mtList div:after {
  content: "";
  width: 20px;
  height: 30px;
  position: absolute;
  display: inline-block;
}
.menuOwall .owallmtArea__mtList div:before {
  border-left: solid 2px #666666;
  border-top: solid 2px #666666;
  top: 0;
  left: 0;
}
.menuOwall .owallmtArea__mtList div:after {
  border-right: solid 2px #666666;
  border-bottom: solid 2px #666666;
  bottom: 0;
  right: 0;
}
.menuOwall .owallmtArea__mtList div dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuOwall .owallmtArea__mtList div dt::first-letter {
  font-size: 2em;
  color: #0284c7;
  font-weight: bold;
}
.menuOwall .owallmtArea__mtTable h4 {
  font-family: "Noto Sans JP", sans-serif;
  color: #0284c7;
  margin-bottom: 24px;
  font-weight: 400;
}
.menuOwall .owallmtArea__mtTable tr td:not(:first-child) {
  text-align: center;
  width: 14%;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-size: 2rem;
}
.menuOwall .owallmtArea__mtTable tr td:first-of-type {
  text-align: left;
  width: 16%;
}
.menuOwall .owallmeArea {
  margin-bottom: 120px;
}
.menuOwall .owallmeArea__desc {
  margin-bottom: 48px !important;
}
.menuOwall .owallmeArea__meList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 48px;
}
.menuOwall .owallmeArea__meList dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuOwall .owallpaArea {
  margin-bottom: 120px;
}
.menuOwall .owallpaArea__desc {
  margin-bottom: 48px !important;
}
.menuOwall .owallpaArea__paList {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-bottom: 48px;
}
.menuOwall .owallpaArea__paList dt {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuOwall .owallpaArea .owallpaTable h4 {
  font-family: "Noto Sans JP", sans-serif;
  color: #0284c7;
  margin-bottom: 24px;
  font-weight: 400;
}
.menuOwall .owallpaArea .owallpaTable__paChart {
  border-top: 1px #bbbbbb solid;
  border-left: 1px #bbbbbb solid;
  margin-bottom: 48px;
  display: grid;
  grid-template: "pitem_a ... pitem_h ... pitem_o" 48px "pitem_b ... pitem_i ... pitem_p" 48px "pitem_c ... pitem_j ... pitem_q" 48px "pitem_d ... pitem_k ... pitem_r" 48px "pitem_e ... pitem_l ... pitem_r" 48px "pitem_f ... pitem_m ... pitem_s" 48px "pitem_g ... pitem_n ... pitem_t" 48px/40% 0px 1fr 0px 1fr;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_a {
  grid-area: pitem_a;
  background-color: #dddddd;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_b {
  grid-area: pitem_b;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_c {
  grid-area: pitem_c;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_d {
  grid-area: pitem_d;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_e {
  grid-area: pitem_e;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_f {
  grid-area: pitem_f;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_g {
  grid-area: pitem_g;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_h {
  grid-area: pitem_h;
  background-color: #dddddd;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_i {
  grid-area: pitem_i;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_j {
  grid-area: pitem_j;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_k {
  grid-area: pitem_k;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_l {
  grid-area: pitem_l;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_m {
  grid-area: pitem_m;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_n {
  grid-area: pitem_n;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_o {
  grid-area: pitem_o;
  border-bottom: 1px #bbbbbb solid;
  background-color: #dddddd;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_p {
  grid-area: pitem_p;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_q {
  grid-area: pitem_q;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_r {
  grid-area: pitem_r;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_s {
  grid-area: pitem_s;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_t {
  grid-area: pitem_t;
  border-bottom: 1px #bbbbbb solid;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_a,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_b,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_c,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_d,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_e,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_f,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_g {
  display: flex;
  align-items: center;
  padding-left: 16px;
  border-bottom: 1px #bbbbbb solid;
  border-right: 1px #bbbbbb solid;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_h,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_i,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_j,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_k,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_l,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_m,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_n {
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px #bbbbbb solid;
  border-right: 1px #bbbbbb solid;
}
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_o,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_p,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_q,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_r,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_s,
.menuOwall .owallpaArea .owallpaTable__paChart .pitem_t {
  display: flex;
  align-items: center;
  justify-content: center;
  border-right: 1px #bbbbbb solid;
}
.menuOwall .owallpaArea__paTable h4 {
  font-family: "Noto Sans JP", sans-serif;
  color: #0284c7;
  margin-bottom: 24px;
  font-weight: 400;
}
.menuOwall .owallpaArea__paTable tr td:not(:first-child) {
  text-align: center;
  width: 14%;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-size: 2rem;
}
.menuOwall .owallpaArea__paTable tr td:first-of-type {
  text-align: left;
  width: 16%;
}

.menuBoiler .boilerlcArea {
  margin-bottom: 120px;
}
.menuBoiler .boilerlcArea__desc {
  margin-bottom: 48px !important;
}
.menuBoiler .boilerlcArea__list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  list-style: none !important;
  margin-left: 0 !important;
  margin-bottom: 48px;
}
.menuBoiler .boilerlcArea__list h4 {
  border-bottom: 1px #0284c7 solid;
  margin-bottom: 16px;
}
.menuBoiler .boilercpArea {
  margin-bottom: 120px;
}
.menuBoiler .boilercpArea__desc {
  margin-bottom: 48px !important;
}
.menuBoiler .boilercpArea__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  list-style: none !important;
  margin-left: 0 !important;
  margin-bottom: 48px;
}
.menuBoiler .boilercpArea h4 {
  font-family: "Noto Sans JP", sans-serif;
  color: #0284c7;
  margin-bottom: 24px;
  font-weight: 400;
}
.menuBoiler .boilertyArea {
  margin-bottom: 120px;
}
.menuBoiler .boilertyArea__desc {
  margin-bottom: 48px !important;
}
.menuBoiler .boilertyArea__list {
  margin-bottom: 24px;
}
.menuBoiler .boilertyArea__table tr td:not(:first-child) {
  text-align: center;
  width: 19%;
  font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
  font-size: 2rem;
}
.menuBoiler .boilertyArea__table tr td:first-of-type {
  text-align: left;
  width: 24%;
}
.menuBoiler .boilerecArea {
  margin-bottom: 120px;
}
.menuBoiler .boilerecArea__desc {
  margin-bottom: 48px !important;
}
.menuBoiler .boilerecArea .ecoBlock__wrap {
  display: grid;
  grid-template-columns: 60% 1fr;
  gap: 48px;
}
.menuBoiler .boilerecArea .ecoBlock__wrap2 {
  display: grid;
  grid-template-columns: 1fr 60%;
  gap: 48px;
}
.menuBoiler .boilerecArea .ecoBlock__cont {
  display: flex;
  align-items: center;
}
.menuBoiler .boilerecArea .ecoBlock__cont h4 {
  font-family: "Noto Sans JP", sans-serif;
  color: #0284c7;
  margin-bottom: 48px;
  font-weight: 400;
}
.menuBoiler .boilerecArea .ecoBlock__img p {
  font-size: x-small;
  line-height: 1.8;
}

/* --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 1200px) {
  .menu__mainVisual {
    margin: 0 auto;
    width: 100%;
  }
}
/* --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 770px) {
  .menu__mainVisual.-mb {
    margin-bottom: 24px;
  }
  .menu__guide {
    grid-template-columns: 1fr;
  }
  .menu .mainToc__menu .menuItem {
    grid-template-columns: repeat(2, 1fr);
  }
  .menu .mainToc__intro {
    grid-template-columns: 1fr;
    grid-auto-flow: row dense;
  }
  .menu .mainToc__intro .introDesc__title {
    font-size: 19px;
  }
  .menu .mainToc__intro .introDesc p {
    font-size: small;
    line-height: 1.6em;
  }
  .menu .catchphrase {
    margin: 0 0 22px 0;
    width: 100%;
  }
  .menu .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin-right: auto;
    margin: auto;
    display: block;
    text-align: center;
  }
  .menu .catchphrase h3 {
    margin: 0 auto;
  }
  .menu .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .menu .outlineEach__list .listItem h4 {
    font-size: 1.8rem;
  }
  .menu .outlineEach__list .listItem h4 img {
    width: 64px;
  }
  .menu .outlineEach__list .listItem__cont {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .menu .outlineEach__list .listItem__itemDesc ul {
    grid-template-columns: 1fr;
  }
  .menu .supportArea {
    margin-bottom: 64px;
  }
  .menu .supportArea .catchphrase {
    width: 100%;
  }
  .menu .supportArea .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  .menu .supportArea .catchphrase h3 {
    max-inline-size: none;
  }
  .menu .supportArea .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .menu .supportArea img {
    width: 90%;
  }
  .menu .supportArea__dlBox {
    width: 100%;
    padding: 0 25px;
  }
  .menu .supportArea__dlKyoto {
    gap: 5px;
    flex-wrap: wrap;
    font-size: 12px;
  }
  .menu .supportArea__dlShiga {
    gap: 5px;
    flex-wrap: wrap;
    font-size: 12px;
    flex-direction: inherit;
  }
  .menu .supportArea__cmt {
    width: 100%;
    padding: 20px 35px;
  }
  .reformMenu__ttl {
    font-size: 26px !important;
    line-height: 1.5 !important;
    margin: 0 auto !important;
    display: block;
    text-align: center;
  }
  .reformMenu .desc {
    display: block;
    text-align: center;
  }
  .reformMenu .rfProduct__list {
    grid-template-columns: repeat(1, 1fr);
  }
  .reformMenu .rfProduct__costDl {
    width: 100%;
  }
  .reformMenu .rfProduct__cmt {
    padding: 0 16px;
  }
  .menuKitchen .layoutArea__list {
    display: block;
  }
  .menuKitchen .layoutArea__list .layoutItem h4 {
    margin: 24px 0;
  }
  .menuKitchen .layoutArea__list .layoutItem__wrap {
    padding: 0;
  }
  .menuKitchen .layoutArea__list .layoutItem__i {
    width: 50%;
  }
  .menuKitchen .layoutArea__list .layoutItem__space {
    display: none;
  }
  .menuKitchen .sizingArea__desc img {
    width: 100%;
  }
  .menuKitchen .sizingArea__wrap {
    display: block;
  }
  .menuKitchen .sizingArea__wrap img {
    width: 100%;
  }
  .menuKitchen .eqArea__descWrap {
    display: block;
    margin-bottom: 48px;
  }
  .menuKitchen .eqArea__desc {
    margin-bottom: 32px;
  }
  .menuKitchen .eqArea__desc p {
    margin-bottom: 0 !important;
  }
  .menuKitchen .eqArea__descList {
    display: block;
  }
  .menuKitchen .eqArea__eqList {
    display: block;
  }
  .menuKitchen .eqArea__eqList div {
    margin-bottom: 16px;
  }
  .menuBath .bathszArea .bathSize {
    grid-template-columns: 1fr;
  }
  .menuBath .bathszArea .bathSize__desc {
    grid-row: 2/3;
    grid-column: 1/2;
    margin-bottom: 32px;
  }
  .menuBath .bathszArea .bathSize__img {
    grid-row: 1/2;
    grid-column: 1/2;
  }
  .menuBath .bathszArea .bathSize__sample {
    grid-template-columns: none;
  }
  .menuBath .bathszArea .bathSize__sample li {
    display: flex;
  }
  .menuBath .bathszArea .bathSize__sample li img {
    width: 70%;
  }
  .menuBath .bathmtArea .bathMaterial {
    grid-template-columns: 1fr;
  }
  .menuBath .bathmtArea .bathmtTable tr th {
    writing-mode: vertical-rl;
    text-orientation: upright;
    letter-spacing: 0.8rem;
  }
  .menuBath .bathmtArea .bathmtTable tr td:not(:first-child) {
    vertical-align: middle;
  }
  .menuBath .bathnwArea .bathnwList__introL {
    flex-direction: column-reverse;
  }
  .menuBath .bathnwArea .bathnwList__cmt {
    width: 100%;
  }
  .menuBath .bathnwArea .bathnwList__cmt p {
    margin-bottom: 0;
  }
  .menuBath .bathnwArea .bathnwList__cmt h5 {
    margin-bottom: 16px;
  }
  .menuBath .bathnwArea .bathnwList__img {
    width: 100%;
  }
  .menuToilet .toiletyArea {
    margin-bottom: 48px;
  }
  .menuToilet .toiletyArea .toileType__listAsc {
    flex-direction: column;
    margin-bottom: 48px;
  }
  .menuToilet .toiletyArea .toileType__listDesc {
    flex-direction: column-reverse;
    margin-bottom: 48px;
  }
  .menuToilet .toiletyArea .toileType__cont {
    width: 100%;
  }
  .menuToilet .toiletyArea .toileType__img {
    width: 100%;
  }
  .menuToilet .impointArea {
    margin-bottom: 48px;
  }
  .menuToilet .impointArea__list .drpipeList {
    grid-template-columns: 1fr;
    margin-bottom: 48px;
  }
  .menuToilet .toilenwArea .toilenwList li {
    margin-bottom: 48px;
  }
  .menuToilet .toilenwArea .toilenwList__introR {
    gap: 0;
  }
  .menuToilet .toilenwArea .toilenwList__introL {
    flex-direction: column-reverse;
    gap: 0;
  }
  .menuToilet .toilenwArea .toilenwList__cmt {
    width: 100%;
  }
  .menuToilet .toilenwArea .toilenwList__cmt h5 {
    margin-bottom: 24px;
  }
  .menuToilet .toilenwArea .toilenwList__img {
    width: 100%;
  }
  .menuWashstand .wstandtyArea {
    margin-bottom: 48px;
  }
  .menuWashstand .wstandtyArea__list {
    grid-template-columns: 1fr;
  }
  .menuWashstand .wstandtyArea__list .wstandType h4 {
    margin: 24px 0;
  }
  .menuWashstand .wstandtyArea__list .wstandType__wrap {
    padding: 0;
  }
  .menuWashstand .wstandtyArea__list .wstandType__i {
    width: 50%;
  }
  .menuWashstand .wstandtyArea__list .wstandType__space {
    display: none;
  }
  .menuWashstand .wstandmiArea {
    margin-bottom: 48px;
  }
  .menuWashstand .wstandmiArea__list {
    grid-template-columns: 1fr;
  }
  .menuWashstand .wstandnwArea {
    margin-bottom: 48px;
  }
  .menuWashstand .wstandnwArea .wstandnwDesc {
    flex-direction: column;
  }
  .menuWashstand .wstandnwArea .wstandnwDesc__cont {
    width: 100%;
  }
  .menuWashstand .wstandnwArea .wstandnwDesc__img {
    width: 100%;
  }
  .menuWashstand .wstandnwArea .wstandnwDesc__img iframe {
    width: 100%;
  }
  .menuWashstand .wstandnwArea .wstandnwDesc:nth-child(odd) {
    flex-direction: column-reverse;
  }
  .menuroof .materialArea__mtList {
    grid-template-columns: 1fr;
  }
  .menuOwall .owallmtArea__mtList {
    grid-template-columns: 1fr;
  }
  .menuOwall .owallmtArea__mtTable tr th {
    writing-mode: vertical-rl;
    text-orientation: upright;
    letter-spacing: 0.8rem;
    padding: 10px !important;
  }
  .menuOwall .owallmtArea__mtTable tr td:not(:first-child) {
    vertical-align: middle;
  }
  .menuOwall .owallmeArea__meList {
    grid-template-columns: 1fr;
  }
  .menuOwall .owallpaArea__paList {
    grid-template-columns: 1fr;
  }
}
/* ------------------------------------------------------------------------------------------------------------------------------------------------- */
/*-------------- 基本情報 -------------- */
.prjReform {
  margin: 20px auto 48px !important;
  font-size: 1.3rem;
}
.prjReform dt {
  color: #0284c7;
  font-weight: 400;
  margin-bottom: 4px;
  line-height: 1.6;
}
.prjReform dd {
  margin-bottom: 16px !important;
  border-bottom: 1px #0284c7 dotted;
  line-height: 1.6;
  padding-left: 16px;
}
.prjReform dd span {
  font-size: 3rem;
  color: #dc2626;
}
.prjReform ul {
  list-style: none;
  margin: 0;
}

.fInfo {
  line-height: 1.5em !important;
  margin-bottom: 24px !important;
  font-size: 1.2rem;
}

.prjCont {
  font-size: 1.4rem;
  line-height: 1.6 !important;
}
@media (max-width: 770px) {
  .prjCont {
    font-size: 1.4rem !important;
  }
}
.prjCont::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 1.5px;
  background: linear-gradient(90deg, #ef4444, rgba(232, 160, 43, 0.3));
  margin-right: 12px;
  vertical-align: middle;
  border-radius: 1px;
}

.prjTtl {
  font-size: 1.6rem;
  font-weight: 600;
  color: #0284c7;
  margin-bottom: 2rem;
  position: relative;
  padding-bottom: 1.5rem;
}
.prjTtl::before {
  content: attr(data-en);
  display: block;
  font-size: 1rem;
  font-weight: 400;
  color: #222222;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  opacity: 0.6;
  margin-bottom: 0.5rem;
}
.prjTtl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 30px;
  height: 1px;
  background: #0ea5e9;
  transition: width 0.3s ease;
}
.prjTtl:hover::after {
  width: 60px;
}

.reformList {
  counter-reset: item;
}
.reformList li {
  padding-left: 2rem;
  counter-increment: item;
  position: relative;
}
.reformList li::before {
  content: counter(item, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0.2rem;
  font-size: 1.1rem;
  color: #0ea5e9;
  font-weight: 600;
  opacity: 0.6;
}

/*-------------- 施工事例 -------------- */
.prjMv {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  margin-bottom: 50px;
}
.prjMv h2 {
  padding: 0px;
}

.prjPoint {
  background-color: #f4f4f4;
  padding: 24px 40px 64px;
  line-height: 1.8em;
  margin-bottom: 80px;
  font-size: 1.6rem;
}
.prjPoint__ttl {
  position: relative;
  padding-left: 35px !important;
  margin-bottom: 20px !important;
}
.prjPoint__ttl:before {
  position: absolute;
  font-family: "Font Awesome 5 Free";
  content: "\f0eb";
  background: #ffca2c;
  color: white;
  font-weight: 900;
  font-size: 15px;
  border-radius: 50%;
  left: 0;
  width: 25px;
  height: 25px;
  line-height: 25px;
  text-align: center;
  top: 50%;
  transform: translateY(-50%);
}
.prjPoint__ttl:after {
  /*吹き出しのちょこんと出た部分*/
  content: "";
  display: block;
  position: absolute;
  left: 20px;
  height: 0;
  width: 0;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 12px solid #ffca2c;
  top: 50%;
  transform: translateY(-50%);
}
.prjPoint__Cont {
  font-size: 1.6rem;
}

.prjBefore {
  margin-bottom: 80px;
}
.prjBefore__title {
  font-size: 42px !important;
  margin-bottom: 32px !important;
}
.prjBefore__title span {
  display: flex;
  align-items: center;
  color: #498ee0;
  font-size: 24px;
  text-transform: uppercase;
}
.prjBefore__title span::before {
  content: "";
  display: inline-block;
  margin-right: 20px;
  width: 40px;
  height: 1px;
  background-color: #498ee0;
}
.prjBefore__ttl {
  position: relative;
  padding-left: 60px !important;
  font-size: 20px !important;
}
.prjBefore__ttl::before {
  content: attr(data-en);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  color: rgba(14, 165, 233, 0.3);
  font-size: 50px;
}
.prjBefore__ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100px;
  height: 1px;
  background-color: #0284c7;
}
.prjBefore__Cont {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  margin-bottom: 100px;
}
.prjBefore__Img {
  width: 30%;
}

.beforeWork__list {
  list-style: none !important;
  width: 100% !important;
  margin-left: 0 !important;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.prjHalfway {
  margin-bottom: 80px;
}
.prjHalfway__title {
  font-size: 42px !important;
  margin-bottom: 32px !important;
}
.prjHalfway__title span {
  display: flex;
  align-items: center;
  color: #e8a02b;
  font-size: 24px;
  text-transform: uppercase;
}
.prjHalfway__title span::before {
  content: "";
  display: inline-block;
  margin-right: 20px;
  width: 40px;
  height: 1px;
  background-color: #e8a02b;
}
.prjHalfway__ttl {
  position: relative;
  padding-left: 60px !important;
  font-size: 20px !important;
}
.prjHalfway__ttl::before {
  content: attr(data-en);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  color: rgba(63, 193, 201, 0.3);
  font-size: 50px;
}
.prjHalfway__ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100px;
  height: 1px;
  background-color: rgb(63, 193, 201);
}
.prjHalfway__Cont {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  margin-bottom: 100px;
}
.prjHalfway__Img {
  width: 30%;
}

.halfwayWork__list {
  list-style: none !important;
  width: 100% !important;
  margin-left: 0 !important;
}
.halfwayWork__item {
  width: 415px;
  margin-bottom: 10px;
}

.prjAfter {
  margin-bottom: 80px;
}
.prjAfter__title {
  font-size: 42px !important;
  margin-bottom: 32px !important;
}
.prjAfter__title span {
  display: flex;
  align-items: center;
  color: #e04272;
  font-size: 24px;
  text-transform: uppercase;
}
.prjAfter__title span::before {
  content: "";
  display: inline-block;
  margin-right: 20px;
  width: 40px;
  height: 1px;
  background-color: #e04272;
}
.prjAfter__ttl {
  position: relative;
  padding-left: 60px !important;
  font-size: 20px !important;
}
.prjAfter__ttl::before {
  content: attr(data-en);
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  color: rgba(224, 66, 114, 0.3);
  font-size: 50px;
}
.prjAfter__ttl::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100px;
  height: 1px;
  background-color: rgb(224, 66, 114);
}
.prjAfter__cont {
  margin-bottom: 80px;
}
.prjAfter__wCont {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.prjAfter__tCont {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
}
.prjAfter__sImg {
  margin-bottom: 20px;
}
.prjAfter__wImg {
  width: 49%;
  margin-bottom: 20px;
}
.prjAfter__tImg {
  width: 32%;
  margin-bottom: 20px;
}

.afterWork__list {
  list-style: none !important;
  width: 100% !important;
  margin-left: 0 !important;
}
.afterWork__item {
  width: 415px;
  margin-bottom: 10px !important;
}

.prjMaterial {
  margin-bottom: 80px;
}
.prjMaterial__title {
  font-size: 26px !important;
  margin-bottom: 32px !important;
}
.prjMaterial__title span {
  display: flex;
  align-items: center;
  color: #0284c7;
  font-size: 18px;
  text-transform: uppercase;
}
.prjMaterial__title span::before {
  content: "";
  display: inline-block;
  margin-right: 20px;
  width: 40px;
  height: 1px;
  background-color: #0284c7;
}
.prjMaterial__ttl {
  position: relative;
  padding-left: 1.2em !important; /*アイコン分のスペース*/
  line-height: 1.4 !important;
  font-size: initial !important;
  margin-bottom: 24px !important;
}
.prjMaterial__ttl:before {
  font-family: "Font Awesome 5 Free";
  content: "\f00c"; /*アイコンのユニコード*/
  font-weight: 900;
  position: absolute; /*絶対位置*/
  font-size: 1em; /*サイズ*/
  left: 0; /*アイコンの位置*/
  color: #5ab9ff; /*アイコン色*/
  font-weight: 900;
}
.prjMaterial__list div {
  display: grid;
  grid-template-columns: 20% 1fr;
  margin-bottom: 8px !important;
  -moz-column-gap: 24px;
       column-gap: 24px;
  font-size: 1.2rem;
  border-bottom: 1px #0284c7 dotted;
}
.prjMaterial__list div p {
  margin: 0 !important;
}
.prjMaterial__list div dt,
.prjMaterial__list div dd {
  line-height: 2.6;
  margin-bottom: 0;
}
.prjMaterial__list div dt {
  color: #0284c7;
  text-align: right;
}
.prjMaterial__list div dd::before {
  content: "";
  width: 20px;
  height: 1px;
}
.prjMaterial__cont {
  margin-bottom: 80px;
}
.prjMaterial__sct {
  display: flex;
  margin-bottom: 5px;
  line-height: 1.4em;
  flex-wrap: wrap;
  gap: 2px;
}
.prjMaterial__sct__left {
  width: 20%;
  background-color: #0284c7;
  color: white;
  padding: 3px 10px;
}
.prjMaterial__sct__right {
  width: 78%;
  padding: 3px 5px 3px 20px;
}

.prjVoice {
  background-color: #f4f4f4;
  padding: 24px 40px 64px;
  line-height: 1.8em;
  margin-bottom: 50px;
  font-size: 1.6rem;
}
.prjVoice__ttl {
  position: relative; /*相対位置*/
  padding-left: 2.2em !important; /*アイコン分のスペース*/
  line-height: 1.4 !important; /*行高*/
  margin-bottom: 20px !important;
  font-size: 20px !important;
}
.prjVoice__ttl:before {
  font-family: "Font Awesome 5 Free";
  content: "\f075"; /*アイコンのユニコード*/
  font-weight: 900;
  position: absolute; /*絶対位置*/
  font-size: 1.6em; /*サイズ*/
  left: 0; /*アイコンの位置*/
  top: 0px;
  color: #0284c7; /*アイコン色*/
}

/*-------------- ピックアップ -------------- */
.pickupBA__ttl {
  font-family: "Noto Serif JP", serif;
  font-weight: 400 !important;
  font-size: xx-large !important;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 0 auto 48px !important;
}
.pickupBA__ttl span {
  display: block;
  text-align: center;
  color: #999999;
  font-size: 60%;
  margin-top: 16px;
}
.pickupBA__mainVisual {
  margin-bottom: 96px;
}
.pickupBA__infoList {
  font-size: small;
  margin-bottom: 96px !important;
}
.pickupBA__infoList div {
  display: grid;
  grid-template-columns: 35% 1fr;
  gap: 32px;
  border-bottom: 1px #aaaaaa dotted;
  margin-bottom: 16px;
}
.pickupBA__infoList div dt {
  text-align: right;
}
.pickupBA__infoList div dd {
  margin-bottom: 0;
}
.pickupBA__order, .pickupBA__point, .pickupBA__voice {
  width: 800px;
  margin: 0 auto 96px;
}
.pickupBA__order h3, .pickupBA__point h3, .pickupBA__voice h3 {
  font-family: "Noto Serif JP", serif;
  font-weight: 400 !important;
  font-size: x-large !important;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 0 auto 48px !important;
}
.pickupBA__order p, .pickupBA__point p, .pickupBA__voice p {
  line-height: 1.8;
}
.pickupBA__voice {
  margin-bottom: 192px;
}
.pickupBA__before, .pickupBA__after {
  margin-bottom: 96px;
}
.pickupBA .baImg {
  list-style: none !important;
  width: 100% !important;
  margin-left: 0 !important;
}
.pickupBA .baImg__item {
  width: 590px;
}
.pickupBA__footerVisual {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  max-width: initial !important;
}
.pickupBA__footerVisual img {
  width: 100vw;
  height: 600px;
  -o-object-fit: cover;
     object-fit: cover;
}

/*-------------- デフォルトの変更 -------------- */
#project_list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
#project_list li {
  width: auto !important;
  height: auto !important;
  background-color: #ffffff;
  border-bottom: 1px #cccccc solid;
}
#project_list li .image::before {
  width: 100%;
  height: 100%;
}
#project_list li img {
  width: 100%;
  height: 350px;
  -o-object-fit: cover;
     object-fit: cover;
}
#project_list li .project_catch {
  font-size: 2rem;
  font-weight: bold;
  color: #0284c7;
  position: absolute;
  z-index: 1;
  background-color: #ffffff;
  padding: 5px 10px;
  right: 0;
}
#project_list li .project_catch::after {
  content: "万円";
  font-size: 1.2rem;
  margin-left: 3px;
}
#project_list .title2 {
  padding: 15px 20px 10px;
  color: #333;
  background: #fff;
  width: 100%;
  line-height: 180%;
  font-size: small;
  text-decoration: none;
  position: absolute;
  z-index: 3;
  bottom: 0;
  height: 100px;
}
#project_list .title2:hover {
  color: #0284c7;
}
#project_list .title2 span .project_title {
  margin: 0 0 5px 0;
  font-size: 14px;
}
#project_list .title2::after {
  content: "";
  position: absolute;
  bottom: 3px;
  right: 3px;
  border-style: solid;
  border-width: 0 0 12px 12px;
  border-color: transparent transparent #0284c7 transparent;
}
#project_list .projectCat {
  background-color: #0284c7;
  color: #ffffff;
  padding: 2px 8px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-right: 8px;
}

.tax-project-cat #project_list li,
.single-project #project_list li,
.archive #project_list li {
  background-color: #f8f5f2;
}
.tax-project-cat #project_list .title2,
.single-project #project_list .title2,
.archive #project_list .title2 {
  background-color: #f8f5f2;
}

.archive #project_list {
  grid-template-columns: repeat(3, 1fr);
}

#project_related .headline {
  position: relative;
  text-align: center;
  color: #0284c7;
  background-color: #ffffff;
  padding: 0;
  font-weight: 400;
  font-size: 2rem;
  margin-bottom: 32px;
}
#project_related .headline span {
  position: relative;
  z-index: 2;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 1em;
  background-color: #fff;
  text-align: left;
}
#project_related .headline::before {
  position: absolute;
  top: 50%;
  z-index: 1;
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #ccc;
}

.archivePrj__ttl {
  margin-bottom: 64px;
}
.archivePrj__ttl img {
  width: 100%;
}

/* --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 770px) {
  /*-------------- 施工事例 -------------- */
  .prjPoint {
    padding: 30px;
  }
  .prjVoice {
    padding: 30px;
  }
  .beforeWork__list {
    display: block;
  }
  .halfwayWork__item {
    width: 100%;
  }
  .afterWork__item {
    width: 100%;
  }
  .prjMaterial__sct__left {
    width: 100%;
  }
  .prjMaterial__sct__right {
    width: 100%;
  }
  .prjMaterial__list div {
    grid-template-columns: 25% 1fr;
  }
  /*-------------- 基本情報 -------------- */
  .fInfo {
    font-size: 1.2rem !important;
  }
  /*-------------- ピックアップ -------------- */
  .pickupBA__ttl {
    font-size: 120% !important;
  }
  .pickupBA__infoList div {
    grid-template-columns: 1fr;
    gap: 0px;
  }
  .pickupBA__infoList div dt {
    text-align: initial;
  }
  .pickupBA__infoList div dd {
    text-align: right;
  }
  .pickupBA__infoList div dd .constDtl {
    list-style: none;
  }
  .pickupBA__order, .pickupBA__point, .pickupBA__voice {
    width: 100%;
  }
  .pickupBA__order h3, .pickupBA__point h3, .pickupBA__voice h3 {
    font-size: large !important;
  }
  .pickupBA__voice {
    margin-bottom: 48px;
  }
  .pickupBA__footerVisual img {
    height: 200px;
  }
  .pickupBA .baImg__item {
    width: 100%;
  }
  /*-------------- デフォルトの変更 -------------- */
  #project_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  #project_list li {
    height: 300px;
  }
  #project_list li .image::before {
    width: 100%;
    height: 100%;
  }
  #project_list li img {
    width: 100%;
    height: 300px;
  }
  #project_list .title2 {
    display: block;
    padding: 10px 10px 10px;
    line-height: 160%;
    height: 100px;
  }
  #project_list .title2 span .project_title {
    margin: 0 0 5px 0;
  }
  .archive #project_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
/* --------------------------------------------------　2025年7月5日　Before After デザイン変更 -------------------------------------------------------- */
#project_side_content h4 {
  font-size: 16px !important;
}

.projectArticle {
  max-width: 850px;
  margin: 0 auto;
  padding: 0 20px;
}
@media (max-width: 770px) {
  .projectArticle {
    padding: 0 15px;
  }
}

/* スクロールアニメーション用 */
.fade-in {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* メインビジュアル */
.projectMv {
  margin-bottom: 8rem;
  position: relative;
  overflow: hidden;
}
.projectMv h2 {
  margin: 0;
  position: relative;
}
.projectMv img {
  width: 100%;
  height: auto;
  border-radius: 2px;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.projectMv::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -20%;
  width: 60%;
  height: 150%;
  background: linear-gradient(135deg, transparent 30%, #f0f9ff 100%);
  opacity: 0.3;
  z-index: -1;
  -webkit-animation: floatAnimation 20s infinite ease-in-out;
          animation: floatAnimation 20s infinite ease-in-out;
}

/* リフォームのポイント */
.projectPoint {
  margin-bottom: 10rem;
  position: relative;
  padding: 4rem 5rem;
  background: linear-gradient(135deg, #f8fafc 0%, transparent 100%);
  border-left: 3px solid #ef4444;
}
@media (max-width: 770px) {
  .projectPoint {
    padding: 3rem 2.5rem;
  }
}
.projectPoint__ttl {
  font-size: clamp(2rem, 2.5vw, 2.4rem) !important;
  font-weight: 500 !important;
  color: #0284c7;
  margin-bottom: 2.5rem !important;
  display: flex;
  align-items: center;
  position: relative;
}
.projectPoint__ttl::before {
  content: "\f0eb";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  background: #ef4444;
  color: white;
  border-radius: 50%;
  margin-right: 1.5rem;
  font-size: 1.8rem;
  box-shadow: 0 4px 12px rgba(232, 160, 43, 0.3);
  transition: all 0.3s ease;
}
@media (max-width: 770px) {
  .projectPoint__ttl::before {
    width: 3.2rem;
    height: 3.2rem;
    font-size: 1.4rem;
  }
}
.projectPoint:hover .projectPoint__ttl::before {
  transform: scale(1.1) rotate(10deg);
  box-shadow: 0 6px 20px rgba(232, 160, 43, 0.4);
}
.projectPoint__Cont {
  font-size: 1.6rem;
  line-height: 2;
  color: #222222;
  position: relative;
  padding-left: 5.5rem;
}
@media (max-width: 770px) {
  .projectPoint__Cont {
    padding-left: 0;
    margin-top: 2rem;
  }
}

/* セクションタイトル共通スタイル */
.projectsectionTitle {
  font-size: clamp(3.2rem, 4vw, 4.2rem) !important;
  font-weight: 300 !important;
  margin-bottom: 4rem !important;
  position: relative;
  padding-bottom: 1.5rem !important;
}
@media (max-width: 770px) {
  .projectsectionTitle {
    font-size: 2.8rem;
  }
}
.projectsectionTitle span {
  display: inline-flex;
  align-items: center;
  font-size: 1.8rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  margin-bottom: 0.5rem;
  opacity: 0.8;
}
@media (max-width: 770px) {
  .projectsectionTitle span {
    font-size: 1.4rem;
  }
}
.projectsectionTitle span::before {
  content: "";
  display: inline-block;
  width: 4rem;
  height: 1px;
  margin-right: 2rem;
  transition: width 0.3s ease;
}
.projectsectionTitle::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 80px;
  height: 2px;
  transition: width 0.3s ease;
}

/* Before Section */
.projectBefore {
  margin-bottom: 10rem;
}
.projectBefore__title {
  composes: projectsectionTitle;
  color: #ef4444;
}
.projectBefore__title span {
  color: #ef4444;
}
.projectBefore__title span::before {
  background-color: #ef4444;
}
.projectBefore__title::after {
  background-color: #ef4444;
}

/* Halfway Section */
.projectHalfway {
  margin-bottom: 10rem;
}
.projectHalfway__title {
  composes: projectsectionTitle;
  color: #ef4444;
}
.projectHalfway__title span {
  color: #ef4444;
}
.projectHalfway__title span::before {
  background-color: #ef4444;
}
.projectHalfway__title::after {
  background-color: #ef4444;
}

/* After Section */
.projectAfter {
  margin-bottom: 10rem;
}
.projectAfter__title {
  composes: projectsectionTitle;
  color: #0284c7;
}
.projectAfter__title span {
  color: #0284c7;
}
.projectAfter__title span::before {
  background-color: #0284c7;
}
.projectAfter__title::after {
  background-color: #0284c7;
}

/* Masonry Layout */
.masonryGrid {
  list-style: none;
  -moz-column-count: 2;
       column-count: 2;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  margin: 0;
  padding: 0;
}
@media (max-width: 770px) {
  .masonryGrid {
    -moz-column-count: 1;
         column-count: 1;
  }
}

.masonryItem {
  -moz-column-break-inside: avoid;
       break-inside: avoid;
  margin-bottom: 2rem;
  position: relative;
  overflow: hidden;
  border-radius: 2px;
  background: white;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  /* 画像にオーバーレイ効果 */
}
.masonryItem:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
}
.masonryItem:hover img {
  transform: scale(1.05);
}
.masonryItem:hover::before {
  opacity: 1;
}
.masonryItem img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.masonryItem::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0, 0, 0, 0.4) 100%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 1;
}

/* 使用建材 */
.projectMaterial {
  margin-bottom: 10rem;
  background: linear-gradient(to right, #f0f9ff 0%, transparent 50%);
  padding: 4rem;
  border-radius: 2px;
  position: relative;
}
@media (max-width: 770px) {
  .projectMaterial {
    padding: 3rem 2.5rem;
  }
}
.projectMaterial__title {
  font-size: clamp(2.4rem, 3vw, 2.8rem) !important;
  font-weight: 400 !important;
  margin-bottom: 3rem !important;
  color: #0284c7;
}
.projectMaterial__title span {
  display: inline-flex;
  align-items: center;
  font-size: 1.6rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #0284c7;
  opacity: 0.8;
}
.projectMaterial__title span::before {
  content: "";
  display: inline-block;
  width: 3rem;
  height: 1px;
  background-color: #0284c7;
  margin-right: 1.5rem;
}
.projectMaterial__list {
  margin: 0;
}
.projectMaterial__list > div {
  display: grid;
  grid-template-columns: 25% 1fr;
  gap: 3rem;
  padding: 1.5rem 0;
  border-bottom: 1px dashed #e2e8f0;
  transition: all 0.3s ease;
}
@media (max-width: 770px) {
  .projectMaterial__list > div {
    grid-template-columns: 1fr;
    gap: 0.5rem;
  }
}
.projectMaterial__list > div:hover {
  padding-left: 1rem;
  background: rgba(74, 172, 168, 0.05);
}
.projectMaterial__list dt {
  font-weight: 500;
  color: #0284c7;
  text-align: right;
  position: relative;
}
@media (max-width: 770px) {
  .projectMaterial__list dt {
    text-align: left;
    margin-bottom: 0.5rem;
  }
}
.projectMaterial__list dt::after {
  content: ":";
  position: absolute;
  right: -1.5rem;
}
@media (max-width: 770px) {
  .projectMaterial__list dt::after {
    content: "";
  }
}
.projectMaterial__list dd {
  color: #222222;
  margin: 0;
}

/* お客様の声 */
.projectVoice {
  background: linear-gradient(135deg, #fffbf7 0%, white 100%);
  padding: 5rem;
  margin-bottom: 8rem;
  border-radius: 2px;
  position: relative;
  overflow: hidden;
}
@media (max-width: 770px) {
  .projectVoice {
    padding: 3rem 2.5rem;
  }
}
.projectVoice::before {
  content: "\f10d";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  position: absolute;
  top: -2rem;
  left: -2rem;
  font-size: 12rem;
  color: #fef2f2;
  opacity: 0.1;
  transform: rotate(-15deg);
}
.projectVoice__ttl {
  font-size: clamp(2rem, 2.5vw, 2.4rem) !important;
  font-weight: 500 !important;
  color: #dc2626;
  margin-bottom: 2.5rem !important;
  display: flex;
  align-items: center;
  position: relative;
}
.projectVoice__ttl::before {
  content: "\f075";
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  background: #ef4444;
  color: white;
  border-radius: 50%;
  margin-right: 1.5rem;
  font-size: 1.8rem;
  box-shadow: 0 4px 12px rgba(232, 160, 43, 0.3);
}
@media (max-width: 770px) {
  .projectVoice__ttl::before {
    width: 3.2rem;
    height: 3.2rem;
    font-size: 1.4rem;
  }
}
.projectVoice__cont {
  font-size: 1.6rem;
  line-height: 2;
  color: #222222;
  position: relative;
  z-index: 1;
  padding-left: 5.5rem;
}
@media (max-width: 770px) {
  .projectVoice__cont {
    padding-left: 0;
    margin-top: 2rem;
  }
}

.loadingShimmer {
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-name: shimmer;
          animation-name: shimmer;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  background: linear-gradient(to right, #f6f7f8 8%, #edeef0 18%, #f6f7f8 33%);
  background-size: 936px 104px;
  position: relative;
}

/* --------------------------------------------------  アニメーション  ------------------------------------------------------------------------------- */
@-webkit-keyframes floatAnimation {
  0%, 100% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(-30px, 20px) rotate(5deg);
  }
}
@keyframes floatAnimation {
  0%, 100% {
    transform: translate(0, 0) rotate(0deg);
  }
  50% {
    transform: translate(-30px, 20px) rotate(5deg);
  }
}
/* 高級感のあるローディングエフェクト */
@-webkit-keyframes shimmer {
  0% {
    background-position: -468px 0;
  }
  100% {
    background-position: 468px 0;
  }
}
@keyframes shimmer {
  0% {
    background-position: -468px 0;
  }
  100% {
    background-position: 468px 0;
  }
}
/* .box {
  @include pc {
    background-color: red;
  }
} */
/*----------------------------------------------------------------- リセット系-----------------------------------------------------------------------------------------------------*/
img {
  max-width: 100%; /* 1 */
  height: auto; /* 1 */
  vertical-align: middle; /* 2 */
  font-style: italic; /* 3 */
  background-repeat: no-repeat; /* 4 */
  background-size: cover; /* 4 */
  shape-margin: 0.75rem; /* 5 */
}

/*---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
.js {
  display: none;
}

body::-webkit-scrollbar {
  width: 16px;
  height: 20px;
}
body::-webkit-scrollbar-thumb {
  background: #0ea5e9;
  border-radius: 100px;
  width: 130px;
}

/* test */
.buttonWrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.buttonWrap__item {
  width: 200px;
  line-height: 2.5;
  border: 1px #000000 solid;
}
.buttonWrap__item--red {
  background-color: red;
}
.buttonWrap__item--blue {
  background-color: blue;
}
.buttonWrap__item--wide {
  width: 400px;
}
.buttonWrap__item.-blue {
  background-color: blue;
}

@media (max-width: 770px) {
  .responsiveVideo {
    width: 100vw; /* 画面幅いっぱい */
    height: 60vh; /* 画面高さの60% */
    -o-object-fit: cover;
       object-fit: cover;
  }
}

/* ---------------------------         ヘッダー用          -------------------------------*/
body {
  /*background-image: url("https://www.rizaim.biz/img/index/headerBack.png");
  background-repeat: no-repeat;
  background-size: 100%;*/
  overflow: hidden;
}

.pc #header {
  height: 144px;
  padding-top: 8px;
  margin-bottom: 12px;
}
.pc #header #header_inner {
  width: 1250px;
  height: 128px;
}
.pc #header .sub-menu {
  top: 40px !important;
  /*display: block !important;*/
}
.pc #header #logo_image {
  z-index: 30;
  top: 30% !important;
}
.pc #header #logo_image .logo img {
  height: 78px;
}
.pc #header .menu-item-has-children a::after {
  font-family: "Font Awesome 5 Free";
  content: "　\f107";
  color: #0ea5e9;
  font-size: 120%;
}
.pc #header .menu-item-has-children ul a::after {
  content: "";
}
.pc #header .headerCp {
  font-size: 14px;
  position: absolute;
  top: 40px;
  left: 275px;
  line-height: 1.4;
}
.pc #header .headerCp span {
  margin-left: 64px;
}
.pc #header .headerInfo {
  display: flex;
  position: absolute;
  top: 4%;
  right: 25px;
  z-index: 1;
  gap: 16px;
}
.pc #header .headerInfo__tel {
  font-size: 200%;
  font-weight: bold;
  letter-spacing: 1px;
  line-height: 0.8;
  margin: auto;
}
.pc #header .headerInfo__tel::before {
  font-family: "Font Awesome 5 Free";
  content: "\f098";
  font-weight: 600;
  margin-right: 6px;
  font-size: 120%;
}
.pc #header .headerInfo__teltime {
  font-size: initial;
  font-weight: inherit;
  letter-spacing: 0px;
}
.pc #header .headerInfo__mail {
  width: 150px;
  height: 72px;
  background: #ef4444;
  color: #ffffff;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.5s ease;
  flex-direction: column;
}
.pc #header .headerInfo__mail:hover {
  background-color: #ffffff;
  color: #ef4444;
  border: 1px #ef4444 solid;
  font-weight: bold;
}
.pc #header .headerInfo__mailicon::before {
  font-family: "Font Awesome 5 Free";
  content: "\f0e0";
  font-weight: 600;
  margin-right: 6px;
  font-size: 220%;
}
.pc #header .headerInfo__tol {
  width: 150px;
  height: 72px;
  background: #0ea5e9;
  color: #ffffff;
  border-radius: 5px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.5s ease;
  flex-direction: column;
}
.pc #header .headerInfo__tol:hover {
  background-color: #ffffff;
  color: #0ea5e9;
  border: 1px #0ea5e9 solid;
  font-weight: bold;
}
.pc #header .headerInfo__tolicon::before {
  font-family: "Font Awesome 5 Free";
  content: "\f2b5";
  font-weight: 600;
  margin-right: 6px;
  font-size: 220%;
}
.pc #header #global_menu {
  float: inherit;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  padding-top: 88px;
}
.pc #header #global_menu .menu {
  display: flex;
}
.pc #header #global_menu ul {
  height: inherit;
}
.pc #header #global_menu ul li {
  border-left: 1px #000000 dotted;
  width: 240px;
}
.pc #header #global_menu ul li:first-child {
  border-left: none;
}
.pc #header #global_menu ul li a {
  height: 40px !important;
  line-height: 40px !important;
  text-align: center;
  font-size: 1.5rem;
}
.pc #header #global_menu ul ul {
  top: 40px !important;
  left: 0px !important;
  width: 230px !important;
}
.pc #header #global_menu ul ul li {
  border-left: none;
  margin-top: 0;
  border-bottom: 2px #ffffff solid;
}
.pc #header #global_menu ul ul li a {
  line-height: 10px !important;
  text-align: left;
}
.pc #header #global_menu ul ul ul {
  top: 0px !important;
  left: 230px !important;
  width: 230px !important;
}
.pc .header_fix #header {
  height: 118px !important;
  background-image: none;
  padding-top: 0px;
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}
.pc .header_fix #header #header_inner {
  width: 1250px;
  height: 118px;
}
.pc .header_fix #header #logo_image {
  top: 33% !important;
}
.pc .header_fix #header #logo_image .logo img {
  height: 50px !important;
}
.pc .header_fix #header #global_menu {
  padding-top: 70px;
  display: block;
}
.pc .header_fix #header #global_menu ul li {
  /*margin-top: 70px;*/
}
.pc .header_fix #header .headerInfo {
  top: 15%;
}
.pc .header_fix #header .headerInfo__teltime {
  display: none;
}
.pc .header_fix #header .headerInfo__mail {
  width: 180px;
  height: 35px;
  flex-direction: row;
}
.pc .header_fix #header .headerInfo__mailicon::before {
  font-size: 120%;
}
.pc .header_fix #header .headerInfo__tol {
  width: 180px;
  height: 35px;
  flex-direction: row;
}
.pc .header_fix #header .headerInfo__tolicon::before {
  font-size: 120%;
}
.pc .header_fix #header .headerCp {
  display: none;
}

/* ---------------------------         フッター用          -------------------------------*/
.contMargin {
  height: 560px;
  position: relative;
}
.contMargin__back {
  position: absolute;
  z-index: 1;
  width: 100%;
  bottom: 0;
}
.contMargin__back img {
  width: 100%;
}

.home #footer_top {
  position: fixed;
  bottom: 150px;
  left: 0;
  right: 0;
}

#return_top a {
  background: #0ea5e9;
}
#return_top a:hover {
  background: #ef4444;
}
#return_top ul {
  display: none;
}

.footerMargin {
  display: none;
}

#footer_address .logo {
  margin-top: 0 !important;
}

/* ---------------------------         front-page用          -------------------------------*/
.subGmenu {
  display: none;
}

.backGround {
  width: 100%;
  scale: 1.1;
  height: 100vh;
  position: fixed;
  opacity: 0.1;
  top: 0;
  pointer-events: none;
  z-index: 99;
}
.backGround__img {
  width: 100%;
  transform-origin: left top;
  -webkit-animation: yuraback 15s linear infinite;
          animation: yuraback 15s linear infinite;
}

@-webkit-keyframes yuraback {
  0%, 100% {
    transform: rotate(2deg);
  }
  50% {
    transform: rotate(-2deg);
  }
}

@keyframes yuraback {
  0%, 100% {
    transform: rotate(2deg);
  }
  50% {
    transform: rotate(-2deg);
  }
}
#index_news {
  padding: 0px 25px !important;
  margin-bottom: 128px;
}
#index_news .curtainLefttoRight {
  opacity: 0;
}
#index_news #index_event_list {
  float: right !important;
}
#index_news #index_info_list {
  float: left !important;
}
#index_news .index_news_list {
  margin-bottom: 0;
}

.informationArea {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 64px;
}
.informationArea__bannerlist {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  gap: 20px;
  list-style: none;
}
.informationArea__bannerlist img {
  width: 100%;
  border-radius: 20px;
  transition: transform 0.3s ease;
}
.informationArea__bannerlist :hover img {
  transform: scale(1.05);
}

.planArea {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 128px;
}
.planArea h3 {
  opacity: 0;
}
.planArea .catchphrase {
  margin: 0 0 40px 0;
  position: relative;
}
.planArea .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.planArea .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.planArea__planUl {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.planArea__planUl li {
  position: relative;
  height: 320px;
}
.planArea__planUl li img {
  max-width: 100%;
  border-bottom: 1px #999999 solid;
}
.planArea__planUl li div {
  position: absolute;
  background-color: #0284c7;
  color: #ffffff;
  font-size: clamp(1.1rem, 1.6927083333vw, 1.3rem);
  display: flex;
  align-items: center;
  flex-direction: column;
  padding-top: 8px;
  width: 192px;
  height: 80px;
  bottom: 0;
  right: 0;
  box-shadow: 0px 5px 10px -5px rgba(50, 50, 50, 0.5);
}
.planArea__planUl li div span {
  font-size: clamp(2.8rem, 4.1666666667vw, 3.2rem);
  margin-top: 3px;
}
.planArea__planUl li div span::after {
  content: "万円～";
  font-size: 1.6rem;
}
.planArea__planUl li div span::before {
  content: "（税込・工事費別）";
  font-size: clamp(1.1rem, 1.6927083333vw, 1.3rem);
  position: absolute;
  top: 58px;
}
.planArea__planUl li div::after {
  content: "";
  position: absolute;
  bottom: 1px;
  right: 1px;
  border-style: solid;
  border-width: 0 0 12px 12px;
  border-color: transparent transparent #ffffff transparent;
}
.planArea__planUl2 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  width: 75%;
  margin: 0 auto;
}
.planArea__planUl2 li {
  position: relative;
  height: 320px;
}
.planArea__planUl2 li img {
  max-width: 100%;
  border-bottom: 1px #999999 solid;
}
.planArea__planUl2 li div {
  position: absolute;
  background-color: #0284c7;
  color: #ffffff;
  font-size: clamp(1.1rem, 1.6927083333vw, 1.3rem);
  display: flex;
  align-items: center;
  flex-direction: column;
  padding-top: 8px;
  width: 192px;
  height: 80px;
  bottom: 0;
  right: 0;
  box-shadow: 0px 5px 10px -5px rgba(50, 50, 50, 0.5);
}
.planArea__planUl2 li div span {
  font-size: clamp(2.8rem, 4.1666666667vw, 3.2rem);
  margin-top: 3px;
}
.planArea__planUl2 li div span::after {
  content: "万円～";
  font-size: 1.6rem;
}
.planArea__planUl2 li div span::before {
  content: "（税込・工事費込）";
  font-size: clamp(1.1rem, 1.6927083333vw, 1.3rem);
  position: absolute;
  top: 58px;
}
.planArea__planUl2 li div::after {
  content: "";
  position: absolute;
  bottom: 1px;
  right: 1px;
  border-style: solid;
  border-width: 0 0 12px 12px;
  border-color: transparent transparent #ffffff transparent;
}
.planArea__subTtl {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 64px auto 16px;
  color: #0ea5e9;
  font-size: 24px;
  font-weight: 500;
}
.planArea__costDl {
  width: 400px;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
}
.planArea__costDl dt {
  width: 50%;
  padding: 4px;
  margin-bottom: 4px;
  border-bottom: 1px #0284c7 solid;
  font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
  display: flex;
  align-items: flex-end;
}
.planArea__costDl dd {
  width: 50%;
  text-align: right;
  padding: 4px;
  margin-bottom: 4px;
  border-bottom: 1px #0284c7 solid;
  font-size: clamp(3.8rem, 5.46875vw, 4.2rem);
  margin-top: 3px;
  color: #0ea5e9;
}
.planArea__costDl dd::after {
  content: "万円～";
  font-size: 1.6rem;
}
.planArea__costDl dd span {
  font-size: 2rem;
}
.planArea__cmt {
  font-size: 80%;
  padding: 20px 0;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin: 0 auto 64px;
  text-align: left;
  line-height: 1.8;
}
.planArea__cmt li {
  list-style: none;
}
.planArea__cmt li::before {
  content: "※　";
  display: inline-block;
  margin-left: -1.5em;
  width: 1.5em;
}

.notionArea {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 45%;
  height: 100vh;
  width: max(100vw, 1200px);
  margin: 0 auto 128px;
}
.notionArea__catch {
  font-family: "M PLUS 1p", sans-serif;
  font-size: 5rem;
  color: #0ea5e9;
  width: 100%;
  z-index: 1;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin-bottom: 40px;
}
.notionArea .notionImg {
  display: flex;
  align-items: center;
}
.notionArea .notionImg__inner {
  background-image: url("https://www.rizaim.biz/img/index/notionArea.webp");
  background-size: cover;
  height: 68%;
  width: 100%;
  background-repeat: no-repeat;
}
.notionArea .notionCont {
  display: flex;
  align-items: center;
  justify-content: center;
}
.notionArea .notionCont__inner {
  width: clamp(400px, 20.8333333333vw, 480px);
}
.notionArea .notionCont__inner p {
  line-height: 2;
  letter-spacing: 1.4px;
  font-size: small;
}
.notionArea .notionCont__ttlup {
  font-size: clamp(2.2rem, 1.5714285714vw, 2.7rem);
  line-height: 1.4;
  font-weight: 500;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  opacity: 0;
}
.notionArea .notionCont__ttlud {
  margin-bottom: 40px;
  font-size: clamp(2.2rem, 1.5714285714vw, 2.7rem);
  line-height: 1.4;
  font-weight: 500;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-right: 0;
  margin-left: auto;
  opacity: 0;
}

.bannerArea {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 128px;
}
.bannerArea .bannerList {
  list-style: none;
  margin-left: 0 !important;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.bannerArea .bannerList img {
  max-width: 100%;
}

.mainBanner {
  width: 1200px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  margin-bottom: 128px;
}

.exConst {
  background-color: #f8f5f2;
  width: 100%;
  padding: 80px 0 128px;
  margin-bottom: 128px;
  /*   .prjHead {
    color: color.$mainColor;
    font-size: 2em;
    margin: 0 auto;
    padding: 32px 32px 56px;
    width: fit-content;
    font-weight: 600;
    background-image: url("https://www.rizaim.biz/img/index/prjHead__bg.png");
    background-repeat: no-repeat;
    &--point {
      display: block;
      font-size: 14px;
      margin-top: 10px;
      position: relative;
      text-align: center;
      font-weight: 400;
    }
  } */
}
.exConst #index_project {
  position: relative;
  width: 1250px;
  padding: 0 25px;
}
.exConst #index_project .catchphrase {
  margin: 0 auto 40px;
  width: 1200px;
  text-align: initial;
}
.exConst #index_project .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.exConst #index_project .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.exConst #index_project h3 {
  opacity: 0;
}
.exConst #index_project .pjLinkwrap {
  width: 1250px;
  padding: 0 25px;
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  margin: auto;
}
.exConst #index_project .index_project_link {
  background-color: #bbbbbb;
  width: 170px;
  height: 45px;
  line-height: 45px;
  display: block;
  text-decoration: none;
  color: #fff;
  text-align: center;
  position: absolute;
  right: 25px;
}
.exConst #index_project .index_project_link:hover {
  background-color: #0284c7;
}

.rcBanner {
  width: 1200px;
  display: flex;
  gap: 10px;
  margin-bottom: 128px;
  justify-content: space-between;
  flex-wrap: wrap;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
}

/* #index_box {
  background-color: color.$backColor;
} */
.index3Box {
  background-color: #f8f5f2;
  width: 100%;
  text-align: center;
}
.index3Box__wrap {
  width: 1250px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 96px 25px 160px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.index3Box__block {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  display: inline-block;
}
.index3Box__blockWrap {
  margin-bottom: 24px;
}
.index3Box__blockCircle {
  color: #0284c7;
  transition-duration: 0.4s;
}
.index3Box__blockCircle2 {
  color: #aaaaaa;
  transform: scale(1.2);
}
.index3Box__blockIcon {
  color: #ffffff;
  pointer-events: none;
}
.index3Box__block h3 {
  margin-bottom: 16px;
}
.index3Box__block p {
  padding: 0 24px;
  font-size: 90%;
  line-height: 1.8;
  color: #666666;
}
.index3Box .fa-5x {
  font-size: 3em;
}
.index3Box .ovArea {
  width: 1250px;
  margin: 0 auto;
  padding: 120px 25px 0;
  box-sizing: border-box;
  text-align: center;
}
.index3Box .ovArea h3 {
  margin-bottom: 32px;
  font-size: 2rem;
}
.index3Box .ovArea p {
  line-height: 1.8;
  font-size: 90%;
  color: #666666;
}

.fpAccess {
  font-size: 40px;
  line-height: 200%;
  text-align: center;
  margin-bottom: 128px;
}
.fpAccess .catchphrase {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 40px;
  position: relative;
  text-align: initial;
}
.fpAccess .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.fpAccess .catchphrase h3 {
  font-weight: 400;
  margin-bottom: 24px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  opacity: 0;
}
.fpAccess .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.fpAccess__list {
  max-width: 600px;
  margin: 40px auto;
  line-height: initial;
}
.fpAccess__list li {
  position: relative;
  padding: 0.5em 1em 0.5em 2.3em;
  margin-bottom: 5px;
  font-size: clamp(12px, 3.2vw, 15px);
  border-bottom: 1px solid #0284c7;
}
.fpAccess__cont {
  font-size: 15px;
  line-height: initial;
}

.supArea {
  line-height: 200%;
  text-align: center;
  margin-bottom: 128px;
}
.supArea .catchphrase {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 40px;
  position: relative;
  text-align: initial;
}
.supArea .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.supArea .catchphrase h3 {
  font-weight: 400;
  margin-bottom: 24px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  opacity: 0;
}
.supArea .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.supArea img {
  width: 600px;
  margin-bottom: 40px;
}
.supArea__dlBox {
  width: max(45%, 800px);
  margin: 0 auto;
}
.supArea__dlKyoto {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.supArea__dlKyoto dt {
  background-color: #ef4444;
  color: #ffffff;
  width: 100px;
}
.supArea__dlKyoto dd {
  background-color: #ffffff;
  padding: 0 5px;
}
.supArea__dlShiga {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  flex-direction: row-reverse;
}
.supArea__dlShiga dt {
  background-color: #0284c7;
  color: #ffffff;
  width: 100px;
}
.supArea__dlShiga dd {
  background-color: #ffffff;
  padding: 0 5px;
}
.supArea__cmt {
  font-size: 80%;
  padding: 20px 0;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 0 auto;
  text-align: left;
  line-height: 1.8;
}
.supArea__cmt li {
  list-style: none;
}
.supArea__cmt li::before {
  content: "※　";
  display: inline-block;
  margin-left: -1.5em;
  width: 1.5em;
}

#index_blog {
  margin-bottom: 128px !important;
  padding: 0 25px !important;
}
#index_blog h3 {
  opacity: 0;
}
#index_blog .index_blog_link {
  top: 20px !important;
}
#index_blog #blog_list .info {
  background: #f8f5f2;
}

.onlineInfo {
  width: 1250px;
  margin: 0 auto;
  margin-bottom: 128px;
  padding: 0px 25px 0;
  box-sizing: border-box;
  display: flex;
  justify-content: space-between;
  text-align: center;
  gap: 10px;
}
.onlineInfo__left {
  width: 45%;
}
.onlineInfo__left__qr {
  margin-top: 100px;
}
.onlineInfo__left__qr img {
  width: 50%;
}
.onlineInfo__ttl {
  overflow: hidden;
  text-align: center;
  margin-bottom: 50px;
}
.onlineInfo__ttl span {
  position: relative;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 1em;
  text-align: left;
  font-size: 1.8em;
  font-weight: initial;
}
.onlineInfo__ttl span::before, .onlineInfo__ttl span::after {
  position: absolute;
  top: 50%;
  content: "";
  width: 400%;
  height: 1px;
  background-color: #ccc;
}
.onlineInfo__ttl span::before {
  right: 100%;
}
.onlineInfo__ttl span::after {
  left: 100%;
}
.onlineInfo__right {
  width: 50%;
  margin-top: -34px;
}
.onlineInfo__right__banner {
  display: flex;
  justify-content: space-between;
  margin-top: 24px;
}
.onlineInfo__right__banner img {
  width: 280px;
}

/* .catchphrase {
  text-align: center;
  margin: 0 0 100px 0;
  .headline {
    line-height: 200%;
    margin: 0 0 5px 0;
    font-weight: 500;
  }
  .desc {
    line-height: 2.2;
    margin: 0 0 35px 0;
  }
} */
.pickupArea {
  margin-bottom: 128px;
  background-color: #f8f5f2;
  padding: 128px 0;
  background-image: url("https://www.rizaim.biz/img/index/pickupArea__back.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
.pickupArea .catchphrase {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto 40px;
  position: relative;
}
.pickupArea .catchphrase .headline {
  font-size: 40px;
  line-height: 200%;
  margin: 0 30px 0 0;
  display: inline-block;
  vertical-align: middle;
}
.pickupArea .catchphrase h3 {
  font-weight: 400;
  margin-bottom: 24px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  font-size: 40px;
  line-height: 200%;
  text-align: center;
  opacity: 0;
}
.pickupArea .catchphrase .desc {
  font-size: 14px;
  line-height: 200%;
  margin: 0;
  display: inline-block;
  vertical-align: middle;
}
.pickupArea__pList {
  width: 100%;
}
.pickupArea__listItem {
  /* width: 1490px; */
  width: max(75vw, 1250px);
  padding: 0 25px;
  margin: 0 auto;
  position: relative;
  height: 624px;
  background-size: 100%;
}
.pickupArea__listItem img {
  position: absolute;
  width: 660px;
  height: 440px;
  -o-object-fit: cover;
     object-fit: cover;
  border-bottom: 1px #666666 solid;
  z-index: 2;
}
.pickupArea__listItem .pickupArea__lDetail {
  position: absolute;
  width: 780px;
  height: 456px;
  background-color: rgb(255, 255, 255);
  top: 120px;
  letter-spacing: 1.4px;
  line-height: 1.6;
  border-bottom: 1px #cccccc solid;
}
.pickupArea__listItem h4 {
  color: #0284c7;
  font-weight: 500;
  font-size: 2rem;
  margin-bottom: 32px;
}
.pickupArea__listItem:nth-child(odd) img {
  left: 0;
}
.pickupArea__listItem:nth-child(odd) .pickupArea__lDetail {
  left: 412px;
  padding: 64px 80px 80px 328px;
}
.pickupArea__listItem:nth-child(odd) .pickupArea__btn {
  right: 80px;
}
.pickupArea__listItem:nth-child(even) img {
  right: 0;
}
.pickupArea__listItem:nth-child(even) .pickupArea__lDetail {
  right: 412px;
  padding: 64px 328px 80px 80px;
}
.pickupArea__listItem:nth-child(even) .pickupArea__btn {
  left: 322px;
}
.pickupArea__text {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 24px;
}
.pickupArea__note {
  padding-top: 24px;
  border-top: 1px #cccccc solid;
}
.pickupArea__btn {
  position: absolute;
  bottom: 64px;
}
.pickupArea__list {
  width: 1250px;
  padding: 0 25px;
  margin: 0 auto;
}
.pickupArea__list .pickupItem {
  display: flex;
  flex-wrap: nowrap;
  margin-bottom: 48px;
  position: relative;
}
.pickupArea__list .pickupItem__img {
  width: 50%;
  padding: 96px 48px;
  background-color: #ffffff;
  display: flex;
  justify-content: center;
}
.pickupArea__list .pickupItem__img img {
  width: 480px;
  -o-object-fit: cover;
     object-fit: cover;
}
.pickupArea__list .pickupItem__point {
  position: absolute;
  top: 16px;
  right: 16px;
}
.pickupArea__list .pickupItem__point img {
  width: 120px;
}
.pickupArea__list .pickupItem .pickupCont {
  width: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #ffffff;
}
.pickupArea__list .pickupItem .pickupCont__wrap {
  width: 60%;
}
.pickupArea__list .pickupItem .pickupCont h4 {
  font-family: "Noto Serif JP", serif;
  color: #0284c7;
  font-weight: 500;
  font-size: 1.8rem;
  margin-bottom: 32px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
}
.pickupArea__list .pickupItem .pickupCont p {
  line-height: 1.8;
  font-size: small;
}
.pickupArea__list .pickupItem .pickupCont__text {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 24px;
}
.pickupArea__list .pickupItem .pickupCont__note {
  padding-top: 24px;
  border-top: 1px #cccccc solid;
}
.pickupArea__list .pickupItem .pickupCont__btn {
  display: flex;
  justify-content: flex-end;
}

.fpReview {
  width: 1200px;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  margin-bottom: 128px;
}

.add-control .cfBanner,
.add-control .cfBanner2 {
  position: fixed;
  z-index: 32;
  overflow: hidden;
}
.add-control .cfBanner__btn,
.add-control .cfBanner2__btn {
  background: #ffffff;
  padding: 1px;
  border-radius: 50%;
  text-align: center;
  display: table;
  cursor: pointer;
  position: absolute;
  right: 0px;
  top: 0;
  font-size: 3rem;
}
.add-control .cfBanner__btn:hover,
.add-control .cfBanner2__btn:hover {
  cursor: pointer;
}
.add-control .cfBanner__btn:active,
.add-control .cfBanner2__btn:active {
  background: rgb(132, 204, 201);
}
.add-control .cfBanner .flBox,
.add-control .cfBanner2 .flBox {
  padding-top: 12px;
}
.add-control .cfBanner .flBox img,
.add-control .cfBanner2 .flBox img {
  width: 200px;
}
.add-control .checkBox,
.add-control .checkBox2 {
  display: none;
}
.add-control .cfBanner {
  bottom: 60px;
  right: 50px;
}
.add-control .cfBanner #closeCheck:checked ~ .cfBanner__btn {
  display: none;
}
.add-control .cfBanner #closeCheck:checked ~ .flBox {
  display: none;
}
.add-control .cfBanner2 {
  bottom: 60px;
  left: 50px;
}
.add-control .cfBanner2 #closeCheck2:checked ~ .cfBanner2__btn {
  display: none;
}
.add-control .cfBanner2 #closeCheck2:checked ~ .flBox {
  display: none;
}

.infoArea__block {
  position: fixed;
  z-index: 31;
  overflow: hidden;
  background-color: #58cdc8;
  right: -10px;
  bottom: 240px;
  color: #ffffff;
  padding: 16px;
  border-radius: 10px;
  width: 56px;
}
.infoArea__block:hover {
  width: 72px;
  background-color: #e67a7a;
  transition-duration: 0.4s;
}
.infoArea__block2 {
  position: fixed;
  z-index: 31;
  overflow: hidden;
  background-color: #58cdc8;
  right: -10px;
  bottom: 90px;
  color: #ffffff;
  padding: 16px;
  border-radius: 10px;
  width: 56px;
}
.infoArea__block2:hover {
  width: 72px;
  background-color: #e67a7a;
  transition-duration: 0.4s;
}
.infoArea a {
  text-decoration: none;
  color: #ffffff;
}
.infoArea a:link {
  color: #ffffff;
}
.infoArea a:hover {
  color: #ffffff;
}
.infoArea__cont {
  writing-mode: vertical-rl;
}

.verticalBanner {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 20; /* 最前面に表示するための z-index を設定 */
  overflow: hidden; /* 画像が親要素からはみ出ないように */
}
.verticalBanner img {
  width: 100%; /* 画像の幅を100%に設定 */
  height: 100%; /* 画像の高さを100%に設定 */
  -o-object-fit: cover;
     object-fit: cover; /* 画像が親要素にフィットするように設定 */
}

.contactArea {
  position: fixed;
  bottom: 16px;
  right: 32px;
  z-index: 30;
  overflow: hidden;
  -webkit-animation: fuwafuwa 3s infinite ease-in-out 0.8s alternate;
          animation: fuwafuwa 3s infinite ease-in-out 0.8s alternate;
  transition: 1.5s ease-in-out;
}
.contactArea:hover img {
  transform: rotateY(360deg);
  transition-duration: 0.5s;
}
.contactArea img {
  width: 250px;
  transition-duration: 0.5s;
}

@-webkit-keyframes fuwafuwa {
  0% {
    transform: translate(0, 0) rotate(-7deg);
  }
  50% {
    transform: translate(0, -30px) rotate(0deg);
  }
  100% {
    transform: translate(0, 0) rotate(7deg);
  }
}

@keyframes fuwafuwa {
  0% {
    transform: translate(0, 0) rotate(-7deg);
  }
  50% {
    transform: translate(0, -30px) rotate(0deg);
  }
  100% {
    transform: translate(0, 0) rotate(7deg);
  }
}
/* ------         front-page カーテン用          ------ */
.curtainLefttoRight {
  position: relative;
}

.curtainLefttoRight.visible {
  -webkit-animation-name: curtainLeftFadeIn;
          animation-name: curtainLeftFadeIn;
  -webkit-animation-duration: 1.2s;
          animation-duration: 1.2s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  opacity: 1 !important;
}

.curtainLefttoRight.visible:before {
  display: block;
  content: "";
  position: absolute;
  z-index: 999;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  transform: scaleX(0);
  background-color: #0ea5e9;
  -webkit-animation-name: curtainLeft;
          animation-name: curtainLeft;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes curtainLeftFadeIn {
  0% {
    opacity: 0;
    color: #ffffff;
  }
  30% {
    opacity: 0;
    color: #ffffff;
  }
  50% {
    opacity: 1;
    color: #0284c7;
  }
  100% {
    opacity: 1;
    color: #0284c7;
  }
}

@keyframes curtainLeftFadeIn {
  0% {
    opacity: 0;
    color: #ffffff;
  }
  30% {
    opacity: 0;
    color: #ffffff;
  }
  50% {
    opacity: 1;
    color: #0284c7;
  }
  100% {
    opacity: 1;
    color: #0284c7;
  }
}
@-webkit-keyframes curtainLeft {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
@keyframes curtainLeft {
  0% {
    transform-origin: left;
    transform: scaleX(0);
  }
  50% {
    transform-origin: left;
    transform: scaleX(1);
  }
  50.001% {
    transform-origin: right;
  }
  100% {
    transform-origin: right;
    transform: scaleX(0);
  }
}
/* ------         front-page スライダー文字パーティクル用          ------ */
.fontAnime {
  position: relative;
  width: 100%;
}
.fontAnime:before {
  content: "";
  display: block;
  padding-top: 33.4%; /* 高さを幅の75%に固定 */
}
.fontAnime__wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
}
.fontAnime .aniWrap {
  display: flex;
  flex-wrap: wrap;
  width: 1200px;
  align-items: flex-end;
  font-size: 5em;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  color: #0284c7;
  font-weight: 900;
}
.fontAnime .aniWrapsub {
  display: flex;
  flex-wrap: wrap;
  width: 1200px;
  font-size: 3em;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  color: #0284c7;
}

/* ------         未使用パネルアニメ          ------ */
.aniWrap2 {
  aspect-ratio: 12/4;
  position: relative;
}
.aniWrap2 p {
  color: #ffffff;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8vw;
  font-size: 7rem;
  margin: 0;
  font-family: "M PLUS 1p", sans-serif;
  transition: all 0.8s cubic-bezier(0.785, 0.135, 0.15, 0.86);
  opacity: 0;
}
.aniWrap2 p.-text-active {
  transition-delay: 0.6s;
  opacity: 1;
  left: 10vw;
}
.aniWrap2 .background-border {
  width: 100%;
  height: 100%;
  background-color: #58cdc8;
}
.aniWrap2 .-border {
  height: 100%;
  display: flex;
}
.aniWrap2 .-border-item {
  flex-grow: 1;
  background-color: #ffffff;
  transform: scaleX(1);
  transform-origin: right;
  transition: transform 0.6s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}
.aniWrap2 .-active .-border-item {
  transform: scaleX(0);
}

.-border-item:nth-child(1) {
  transition-delay: 0s;
}

.-border-item:nth-child(2) {
  transition-delay: 0.02s;
}

.-border-item:nth-child(3) {
  transition-delay: 0.04s;
}

.-border-item:nth-child(4) {
  transition-delay: 0.06s;
}

.-border-item:nth-child(5) {
  transition-delay: 0.08s;
}

.-border-item:nth-child(6) {
  transition-delay: 0.1s;
}

.-border-item:nth-child(7) {
  transition-delay: 0.12s;
}

.-border-item:nth-child(8) {
  transition-delay: 0.14s;
}

.-border-item:nth-child(9) {
  transition-delay: 0.16s;
}

.-border-item:nth-child(10) {
  transition-delay: 0.18s;
}

.-border-item:nth-child(11) {
  transition-delay: 0.2s;
}

.-border-item:nth-child(12) {
  transition-delay: 0.22s;
}

.-border-item:nth-child(13) {
  transition-delay: 0.24s;
}

.-border-item:nth-child(14) {
  transition-delay: 0.26s;
}

.-border-item:nth-child(15) {
  transition-delay: 0.28s;
}

/* ------         front-page 背景アニメ用          ------ */
.area {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  z-index: 0;
  pointer-events: none;
}

.circles {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.circles li {
  position: absolute;
  display: block;
  list-style: none;
  width: 20px;
  height: 20px;
  background: #58cdc8;
  -webkit-animation: animate 100s linear infinite;
          animation: animate 100s linear infinite;
  bottom: -150px;
}
.circles li:nth-child(1) {
  left: 25%;
  width: 80px;
  height: 80px;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}
.circles li:nth-child(2) {
  left: 10%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
  -webkit-animation-duration: 12s;
          animation-duration: 12s;
}
.circles li:nth-child(3) {
  left: 70%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 4s;
          animation-delay: 4s;
}
.circles li:nth-child(4) {
  left: 40%;
  width: 60px;
  height: 60px;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
  -webkit-animation-duration: 18s;
          animation-duration: 18s;
}
.circles li:nth-child(5) {
  left: 65%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}
.circles li:nth-child(6) {
  left: 75%;
  width: 110px;
  height: 110px;
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
}
.circles li:nth-child(7) {
  left: 35%;
  width: 150px;
  height: 150px;
  -webkit-animation-delay: 7s;
          animation-delay: 7s;
}
.circles li:nth-child(8) {
  left: 50%;
  width: 25px;
  height: 25px;
  -webkit-animation-delay: 15s;
          animation-delay: 15s;
  -webkit-animation-duration: 45s;
          animation-duration: 45s;
}
.circles li:nth-child(9) {
  left: 20%;
  width: 15px;
  height: 15px;
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
  -webkit-animation-duration: 35s;
          animation-duration: 35s;
}
.circles li:nth-child(10) {
  left: 85%;
  width: 150px;
  height: 150px;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
  -webkit-animation-duration: 11s;
          animation-duration: 11s;
}
.circles li:nth-child(11) {
  left: 75%;
  width: 80px;
  height: 80px;
  -webkit-animation-delay: 20s;
          animation-delay: 20s;
}
.circles li:nth-child(12) {
  left: 60%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 12s;
          animation-delay: 12s;
  -webkit-animation-duration: 22s;
          animation-duration: 22s;
}
.circles li:nth-child(13) {
  left: 20%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 24s;
          animation-delay: 24s;
}
.circles li:nth-child(14) {
  left: 45%;
  width: 60px;
  height: 60px;
  -webkit-animation-delay: 20s;
          animation-delay: 20s;
  -webkit-animation-duration: 18s;
          animation-duration: 18s;
}
.circles li:nth-child(15) {
  left: 85%;
  width: 20px;
  height: 20px;
  -webkit-animation-delay: 20s;
          animation-delay: 20s;
}
.circles li:nth-child(16) {
  left: 35%;
  width: 110px;
  height: 110px;
  -webkit-animation-delay: 23s;
          animation-delay: 23s;
}
.circles li:nth-child(17) {
  left: 70%;
  width: 150px;
  height: 150px;
  -webkit-animation-delay: 27s;
          animation-delay: 27s;
}
.circles li:nth-child(18) {
  left: 10%;
  width: 25px;
  height: 25px;
  -webkit-animation-delay: 35s;
          animation-delay: 35s;
  -webkit-animation-duration: 45s;
          animation-duration: 45s;
}
.circles li:nth-child(19) {
  left: 60%;
  width: 15px;
  height: 15px;
  -webkit-animation-delay: 22s;
          animation-delay: 22s;
  -webkit-animation-duration: 35s;
          animation-duration: 35s;
}
.circles li:nth-child(20) {
  left: 25%;
  width: 150px;
  height: 150px;
  -webkit-animation-delay: 20s;
          animation-delay: 20s;
  -webkit-animation-duration: 11s;
          animation-duration: 11s;
}

@-webkit-keyframes animate {
  0% {
    transform: translateY(0);
    opacity: 0.5;
    border-radius: 50%;
  }
  50% {
    transform: translateY(-2250);
    opacity: 0.5;
    border-radius: 50%;
  }
  100% {
    transform: translateY(-4500px);
    opacity: 0;
    border-radius: 50%;
  }
}

@keyframes animate {
  0% {
    transform: translateY(0);
    opacity: 0.5;
    border-radius: 50%;
  }
  50% {
    transform: translateY(-2250);
    opacity: 0.5;
    border-radius: 50%;
  }
  100% {
    transform: translateY(-4500px);
    opacity: 0;
    border-radius: 50%;
  }
}
/* ---------------------------         slick用          -------------------------------*/
.slide-items {
  width: max(100%, 1200px);
  height: 100%;
  margin: 0px auto 96px !important;
}
.slide-items img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.slick-dots li {
  width: 40px !important;
  margin: 0 2px !important;
}

.slick-dots li button:before {
  font-size: 18px !important;
  top: 6px !important;
  background: #0ea5e9;
  height: 5px !important;
  width: 40px !important;
  content: "" !important;
}

.slick-prev:before,
.slick-next:before {
  color: black !important;
  font-size: 30px !important;
}

.slick-arrow {
  z-index: 2 !important;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  background: #fff;
}

.slick-initialized .slick-slide {
  opacity: 0.2;
}

.slick-initialized .slick-slide.slick-active {
  opacity: 1;
}

.slick-prev {
  left: 80px !important;
}
.slick-prev::before {
  position: relative;
  content: "\f0d9" !important;
  font-family: FontAwesome !important;
  background: rgb(255, 255, 255);
  padding: 12px 20px;
  opacity: 1 !important;
  border-radius: 50%;
}
.slick-prev:hover:before {
  -webkit-animation: arrow_prev 0.5s ease-out forwards;
          animation: arrow_prev 0.5s ease-out forwards;
}

.slick-next {
  right: 80px !important;
}
.slick-next::before {
  position: relative;
  content: "\f0da" !important;
  font-family: FontAwesome !important;
  background: rgb(255, 255, 255);
  padding: 12px 20px;
  opacity: 1 !important;
  border-radius: 50%;
}
.slick-next:hover:before {
  -webkit-animation: arrow_next 0.5s ease-out forwards;
          animation: arrow_next 0.5s ease-out forwards;
}

@-webkit-keyframes arrow_prev {
  0% {
    right: 0px;
  }
  50% {
    right: 5px;
  }
  100% {
    right: 0;
  }
}

@keyframes arrow_prev {
  0% {
    right: 0px;
  }
  50% {
    right: 5px;
  }
  100% {
    right: 0;
  }
}
@-webkit-keyframes arrow_next {
  0% {
    left: 0px;
  }
  50% {
    left: 5px;
  }
  100% {
    left: 0;
  }
}
@keyframes arrow_next {
  0% {
    left: 0px;
  }
  50% {
    left: 5px;
  }
  100% {
    left: 0;
  }
}
/* ---------------------------         お問い合わせ用          -------------------------------*/
.FormArea {
  background-color: #f8f5f2;
  padding: 50px;
}
.FormArea .form {
  background-color: #ffffff;
  padding: 30px;
}
.FormArea .form dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  border-bottom: 1px #e5eaf0 solid;
}
.FormArea .form dt {
  flex-basis: 30%;
  padding: 10px;
  margin-bottom: 5px;
  display: flex;
  align-items: center;
}
.FormArea .form dd {
  flex-basis: 65%;
  padding: 10px;
  margin-bottom: 0px !important;
}
.FormArea .form dd textarea {
  height: 264px;
  border-radius: 10px;
  padding: 12px 14px;
  width: 100%;
  border-radius: 5px;
  background: #ffffff;
  border: 1px solid #bac7d6;
  line-height: 1.6;
  box-sizing: border-box;
}
.FormArea .form dd textarea::-moz-placeholder {
  color: #cccccc;
}
.FormArea .form dd textarea::placeholder {
  color: #cccccc;
}
.FormArea .form dd input[type=text],
.FormArea .form dd select {
  border-radius: 10px;
  border-radius: 5px;
  background: #ffffff;
  border: 1px solid #bac7d6;
  max-width: 100%;
  box-sizing: border-box;
  vertical-align: middle;
  padding: 12px 14px;
}
.FormArea .form dd input::-moz-placeholder {
  color: #cccccc;
}
.FormArea .form dd input::placeholder {
  color: #cccccc;
}
.FormArea .form dd input[type=text]:focus,
.FormArea .form dd textarea:focus {
  border: 2px solid #000000 !important;
  padding: 11px 13px !important;
}
.FormArea .form .required dt:after {
  padding: 6px 6px 4px;
  margin-left: 12px;
  font-size: 1.6rem;
  content: "★必須";
  display: inline-block;
  padding: 4px 4px 2px;
  color: #84ccc9;
  font-weight: 700;
  margin-left: 12px;
  line-height: 1;
  font-size: 1.3rem !important;
}
.FormArea .form .SubmitArea {
  margin-top: 50px;
  padding: 10px;
}
.FormArea .form .SubmitArea__btn input {
  display: inline-block;
  text-align: center;
  cursor: pointer;
  padding: 12px 100px;
  background: #e67a7a;
  color: #ffffff !important;
  line-height: 1em;
  transition: 0.3s;
  border: 2px solid #e67a7a;
}
.FormArea .form .SubmitArea__btn input:hover {
  color: #e67a7a !important;
  background: #ffffff;
}

.FormBox {
  display: flex;
}
.FormBox dl {
  margin-right: 50px;
}

.formCont,
.formSpl {
  padding: 10px;
}

.MailConfirm {
  margin-top: 20px;
}

/* box-shadow:水平方向の距離 垂直方向の距離 ぼかし距離 広がり距離 影の色 inset;*/
input:-webkit-autofill {
  box-shadow: 0 0 0px 1000px #ffffff inset !important;
}

.prjReform dt,
dd {
  border-top: initial !important;
}

.htitle1 {
  color: #fff;
  border: 2px dashed #fff;
  background-color: #0ea5e9;
  box-shadow: 0px 0px 0px 10px #0ea5e9;
  padding: 10px !important;
  margin: 0 auto 50px !important;
  width: calc(100% - 20px) !important;
  text-align: center;
  font-size: clamp(1.5em, 2.5vw, 2em) !important;
}

.htitle2 {
  position: relative;
  padding-top: 30px;
  font-size: 26px;
  border-bottom: 1px solid rgb(5, 62, 98);
}
.htitle2::before {
  content: attr(data-en);
  position: absolute;
  top: -15px;
  left: 0;
  color: rgba(5, 62, 98, 0.2);
  font-size: 40px;
  text-transform: uppercase;
  z-index: 1;
}
.htitle2 span {
  position: relative;
  z-index: 2;
}

.telArea {
  background-color: #f8f5f2;
  padding: 50px;
  max-width: 100%;
  margin-bottom: 100px;
}
.telArea a:hover {
  text-decoration: none;
}

.contactTel {
  line-height: 4rem;
  text-align: center;
  background-color: #ffffff;
  max-width: 100%;
  padding: 50px;
}
.contactTel__no {
  font-size: clamp(2.5rem, 2vw + 1rem, 4rem);
  color: #ff0000;
  font-family: "M PLUS 1p", sans-serif;
}
.contactTel__no::before {
  position: relative;
  content: "\f098" !important;
  font-family: FontAwesome !important;
  padding-right: 10px;
}

.contactCap {
  line-height: 2 !important;
  margin: 40px 0 96px !important;
}

.formSecurity {
  display: flex;
  align-items: center;
  gap: 15px;
  margin: 30px auto 0;
  padding: 15px;
  border-radius: 5px;
  background-color: #f1fafa;
  max-width: 480px;
}
.formSecurity__icon {
  color: #4aaca8;
  font-size: 1.5em;
  flex-shrink: 0;
}
.formSecurity__text {
  flex: 1;
}
.formSecurity__title {
  font-weight: bold;
  color: #2d8a86;
  margin-bottom: 5px !important;
  font-size: 0.95em;
}
.formSecurity__desc {
  font-size: 0.85em;
  color: #536b69;
  line-height: 1.4 !important;
}

.newprivacyPolicy {
  font-size: 0.85em;
  text-align: center;
  color: #536b69;
  line-height: 1.5 !important;
}

/* ---------------------------         施行の流れ用          -------------------------------*/
.flowTitle {
  text-align: center;
  margin-bottom: 48px !important;
  color: #0284c7;
  font-size: 2em !important;
}

.mainVisual {
  text-align: center;
  width: 1200px;
}
.mainVisual img {
  width: 100%;
}

.flowCont {
  width: 1200px;
  line-height: 1.4em !important;
  margin-bottom: 100px;
  display: grid;
  grid-template: "... ...... ... ...... ... ...... ..." 10px "... fitem1 ... fitem2 ... fitem3 ..." "... fitem1 ... fitemi ... ...... ..." 30px "... fitem1 ... fitem4 ... fitem5 ..." "... fitem1 ... fitemj ... ...... ..." 30px "... fitem1 ... fitem6 ... fitem7 ..." "... fitem1 ... fitemk ... ...... ..." 30px "... fitem8 ... fitem9 ... fitema ..." "... fitem8 ... fiteml ... ...... ..." 30px "... fitem8 ... fitemb ... fitemc ..." "... fitem8 ... fitemm ... ...... ..." 30px "... fitem8 ... fitemd ... fiteme ..." "... fitem8 ... fitemn ... ...... ..." 30px "... fitemf ... fitemg ... fitemh ..." auto "... ...... ... ...... ... ...... ..." 10px/auto 40px 20px 1fr 64px 200px auto;
}
.flowCont__title1 {
  color: #0284c7;
  margin-bottom: 20px !important;
}
.flowCont__title8 {
  color: #faac05;
  margin-bottom: 20px !important;
}
.flowCont__titlef {
  color: #ef4444;
  margin-bottom: 20px !important;
}

.fItem1 {
  grid-area: fitem1;
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 8px;
  background-color: #0284c7;
  color: #ffffff;
  display: flex;
  align-items: center;
  padding: 30px 10px 10px;
}

.fItem8 {
  grid-area: fitem8;
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 8px;
  background-color: #faac05;
  color: #ffffff;
  display: flex;
  align-items: center;
  padding: 30px 10px 10px;
}

.fItemf {
  grid-area: fitemf;
  writing-mode: vertical-rl;
  text-orientation: upright;
  letter-spacing: 8px;
  background-color: #ef4444;
  color: #ffffff;
  display: flex;
  align-items: center;
  padding: 20px 10px 10px;
}

.fItem2 {
  grid-area: fitem2;
}

.fItem3 {
  grid-area: fitem3;
}

.fItem4 {
  grid-area: fitem4;
}

.fItem5 {
  grid-area: fitem5;
}

.fItem6 {
  grid-area: fitem6;
}

.fItem7 {
  grid-area: fitem7;
}

.fItem9 {
  grid-area: fitem9;
}

.fItema {
  grid-area: fitema;
}

.fItemb {
  grid-area: fitemb;
}

.fItemc {
  grid-area: fitemc;
}

.fItemd {
  grid-area: fitemd;
}

.fIteme {
  grid-area: fiteme;
}

.fItemg {
  grid-area: fitemg;
}

.fItemh {
  grid-area: fitemh;
}

.fItemi {
  grid-area: fitemi;
}

.fItemj {
  grid-area: fitemj;
}

.fItemk {
  grid-area: fitemk;
}

.fIteml {
  grid-area: fiteml;
}

.fItemm {
  grid-area: fitemm;
}

.fItemn {
  grid-area: fitemn;
}

.flw__arrowDown {
  width: 30px;
  margin: 0 auto !important;
}

.flowDetail {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none !important;
  margin-top: 50px;
  margin-left: 0px !important;
}
.flowDetail__cont {
  width: 24%;
  text-align: center;
}

/* ---------------------------         工事内容説明用          -------------------------------*/
.explan {
  width: 1200px;
  display: grid;
  grid-template: "... ...... ...... ...... ... ...... ..." 80px "... explaT explaT explaT ... explaI ..." "... explaF ...... explaC ... explaI ..." 1fr "... ...... ...... ...... ... ...... ..." 10px/auto 152px 16px 1fr 32px 328px auto;
}
.explan__ttl {
  grid-area: explaT;
  background-color: #0ea5e9;
  color: #ffffff;
  padding: 16px !important;
}
.explan__face {
  grid-area: explaF;
}
.explan__cap {
  grid-area: explaC;
  position: relative;
  display: inline-block;
  margin: 1.5em 0 1.5em 15px;
  padding: 17px 20px;
  min-width: 120px;
  max-width: 100%;
  color: #555;
  font-size: 16px;
  line-height: 1.6;
  background: #fff;
  border: solid 1px #555;
  box-sizing: border-box;
  border-radius: 15px;
}
.explan__cap:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -24px;
  margin-top: -12px;
  border: 12px solid transparent;
  border-right: 12px solid #fff;
  z-index: 2;
}
.explan__cap:after {
  content: "";
  position: absolute;
  top: 50%;
  left: -28px;
  margin-top: -14px;
  border: 14px solid transparent;
  border-right: 14px solid #555;
  z-index: 1;
}
.explan__img {
  grid-area: explaI;
}

.explanSub {
  margin: 48px 0 -48px;
  font-size: 130%;
  clear: both;
  line-height: 1.2;
  font-weight: 600;
}
.explanSub--sec {
  margin: 48px 0;
  font-size: 130%;
  clear: both;
  line-height: 1.2;
  font-weight: 600;
}

.circleChara {
  display: inline-block;
  background: #fae9b4;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  text-align: center;
  line-height: 32px;
  border: 1px #000000 solid;
  margin: 3px;
}

.explanDetail {
  display: flex;
  margin: 48px 0;
  font-size: 130%;
  clear: both;
  font-weight: 600;
}
.explanDetail__img {
  width: 85%;
}
.explanDetail__slate {
  position: absolute;
  left: 58%;
  top: 14.5%;
  width: 20%;
  filter: drop-shadow(15px 5px 5px rgba(0, 0, 0, 0.3));
}
.explanDetail p {
  line-height: 1.5;
  margin-top: 16px;
  padding-right: 30px;
}

.constructionList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  list-style: none !important;
  margin-left: 0 !important;
}
.constructionList li {
  border: 1px #cccccc solid;
  position: relative;
}
.constructionList li h3 {
  text-align: center;
  line-height: 2.4;
}
.constructionList li img {
  padding: 0 24px 16px;
}
.constructionList li p {
  padding: 0 24px;
  line-height: 1.6;
}
.constructionList li i {
  font-size: 5rem;
  position: absolute;
  top: 288px;
  right: -33px;
  color: #0284c7;
  z-index: 1;
}
.constructionList__step {
  background-color: #0ea5e9;
  color: #ffffff;
  padding: 4px 24px;
  font-size: 1.4rem;
}

/* ---------------------------         点検・見積り依頼はこちら用          -------------------------------*/
.explainTitle {
  text-align: center;
  margin-bottom: 10px !important;
  color: #84ccc9;
  font-size: clamp(1.5em, 2.5vw, 2em) !important;
  font-weight: bold;
}

.explainCont {
  text-align: center;
  margin-bottom: 30px !important;
}

.explainTtl3 {
  text-align: center;
  margin-bottom: 30px !important;
  color: #ffffff;
  background-color: #84ccc9;
  font-size: clamp(1.5em, 1.625vw, 2em) !important;
  padding: 10px !important;
}

.emphasisCont {
  text-align: center;
  margin-bottom: 10px !important;
  color: #84ccc9;
  font-size: clamp(1.5em, 2.5vw, 2em) !important;
  font-weight: bold;
}

.est__arrowDown {
  margin: 0 auto !important;
  width: 50px;
  margin-bottom: 30px !important;
}

.explainImg {
  display: grid;
  grid-template: "... ...... ... ...... ... ...... ... ...... ..." 10px "... eitem1 ... eitem2 ... eitem3 ... eitem4 ..." "... ...... ... ...... ... ...... ... ...... ..." 10px/auto 1fr 0px 1fr 0px 1fr 0px 1fr auto;
}

.eItem1 {
  grid-area: eitem1;
}

.eItem2 {
  grid-area: eitem2;
}

.eItem3 {
  grid-area: eitem3;
}

.eItem4 {
  grid-area: eitem4;
}

.roofBacont1 {
  display: flex;
  margin-top: 20px;
  justify-content: space-between;
}
.roofBacont1__left {
  width: 60%;
  line-height: 2;
  margin: 0 0 2em 0;
}
.roofBacont1__left img {
  width: 100%;
}
.roofBacont1__right {
  width: 35%;
}
.roofBacont1__right img {
  width: 100%;
}

.roofBacont2 {
  display: flex;
  margin: 20px 0 50px 0;
  justify-content: space-between;
}
.roofBacont2__left {
  width: 35%;
}
.roofBacont2__left img {
  width: 100%;
}
.roofBacont2__right {
  width: 60%;
  line-height: 2;
  margin: 0 0 2em 0;
}
.roofBacont2__right img {
  width: 100%;
}

.roofBacont3 {
  display: flex;
  margin: 20px 0 50px 0;
  justify-content: space-between;
}
.roofBacont3__left {
  width: 35%;
  line-height: 2;
  margin: 0 0 2em 0;
}
.roofBacont3__left img {
  width: 100%;
}
.roofBacont3__right {
  width: 60%;
}
.roofBacont3__right img {
  width: 100%;
}

.estFooter {
  text-align: center;
  font-weight: bold;
  font-size: 1.4em;
}

.emphasisBtn {
  text-align: center;
  margin-bottom: 100px !important;
}
.emphasisBtn a {
  display: inline-block;
  transition: 0.3s;
  perspective: 1000px;
  perspective-origin: 50% 50%;
  vertical-align: bottom;
  overflow: hidden;
}
.emphasisBtn a span {
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  background: #fb9861;
  padding: 18px 300px;
  display: inline-block;
  position: relative;
  transform-origin: 50% 0%;
  transform-style: preserve-3d;
  transition: 0.4s;
}
.emphasisBtn a span:after {
  position: absolute;
  left: 0;
  top: 0;
  content: attr(data-text);
  padding: 18px 300px;
  background-color: #32c3ac;
  display: inline-block;
  transform-origin: 50% 0%;
  transform: translate3d(0, 100%, 0) rotateX(-90deg);
}
.emphasisBtn a:hover span {
  transform: translate3d(0, 0, -60px) rotateX(90deg);
}

/* ---------------------------         こどもみらい住宅支援事業用          -------------------------------*/
#lpSubsidy {
  width: 100vw;
  min-height: 100vh;
  background-image: url("https://www.rizaim.biz/img/lp/subsidy/lpSubsidy__backimg.jpg");
  background-size: cover;
  position: relative;
  margin: 0 calc(50% - 50vw);
}
#lpSubsidy sup {
  vertical-align: super;
  font-size: smaller;
}
#lpSubsidy p {
  margin: 0px;
}
#lpSubsidy .ttlSect {
  width: 600px;
  margin: 0 auto;
}
#lpSubsidy .ttlSect h2 {
  text-align: center;
  color: #f39800;
  font-weight: 900;
  margin-bottom: 32px;
}
#lpSubsidy .ttlSect__cont {
  display: flex;
  gap: 10px;
  margin-bottom: 16px;
}
#lpSubsidy .ttlSect__cont--L {
  width: 50%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#lpSubsidy .ttlSect__cont--R {
  width: 50%;
}
#lpSubsidy .ttlSect__cont--wrap {
  display: flex;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
  margin-bottom: 32px;
  gap: 10px;
}
#lpSubsidy .ttlSect__cont--sp1 {
  font-size: 80px;
  font-weight: 600;
  transform: rotate(-15deg);
}
#lpSubsidy .ttlSect__cont--sp2 {
  font-size: 64px;
  font-weight: 600;
  transform: rotate(15deg);
}
#lpSubsidy .ttlSect__cont--info {
  background-color: #f39800;
  color: #ffffff;
  font-weight: 600;
  border-radius: 15px;
  text-align: center;
  letter-spacing: 5px;
  margin-bottom: 0 !important;
}
#lpSubsidy .ttlSect__cmt {
  width: calc(100% + 120px);
  margin-left: -60px;
  margin-right: -60px;
  text-align: center;
  margin-bottom: 24px;
}
#lpSubsidy .ovSect {
  width: 1200px;
  margin: 0 auto;
}
#lpSubsidy .ovSect__ttl {
  background-color: #f39800;
  color: #ffffff;
  font-weight: 600;
  letter-spacing: 5px;
  text-align: center;
  padding: 8px;
  margin-bottom: 24px;
}
#lpSubsidy .ovSect__cont {
  display: flex;
  gap: 16px;
  margin-bottom: 32px;
}
#lpSubsidy .ovSect__contLt {
  width: 50%;
  background-color: #f39800;
  border-radius: 15px;
  padding: 24px;
}
#lpSubsidy .ovSect__contLt h4 {
  color: #ffffff;
  text-align: center;
}
#lpSubsidy .ovSect__contBlock {
  background-color: #ffffff;
}
#lpSubsidy .ovSect__contBlock hr {
  width: 90%;
  text-align: center;
  margin: 8px auto;
  background-color: #f39800;
  height: 2px;
}
#lpSubsidy .ovSect__contBlock h5 {
  text-align: center;
  background-color: #fee7ad;
  font-weight: normal;
  padding: 8px !important;
}
#lpSubsidy .ovSect__contBlockUnit {
  display: flex;
  gap: 32px;
}
#lpSubsidy .ovSect__contBlockUnitLt {
  width: 40%;
  padding: 0 16px;
  line-height: 1.4;
}
#lpSubsidy .ovSect__contBlockUnitRt {
  width: 60%;
  font-size: 24px;
  line-height: normal;
  font-weight: 600;
  text-align: center;
}
#lpSubsidy .ovSect__contRt {
  width: 50%;
  background-image: url("https://www.rizaim.biz/img/lp/subsidy/ovSect__contRt-img.jpg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position-x: right;
}
#lpSubsidy .ovSect__contRt-block {
  display: flex;
  gap: 24px;
}
#lpSubsidy .ovSect__contRt-blockLt {
  color: #f39800;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.1);
  padding: 20px;
  border-radius: 20px;
  width: 40%;
  line-height: 1.4;
  text-align: center;
  background-color: #ffffff;
}
#lpSubsidy .ovSect__contRt-blockRt {
  width: 60%;
  background-color: #ff0000;
  color: #ffffff;
  border-radius: 10px;
  padding: 16px;
  height: 72px;
  line-height: 1.4;
}
#lpSubsidy .ovSect__contRtimg {
  position: absolute;
}
#lpSubsidy .ovSect__cmt {
  font-size: 80%;
  padding: 20px;
}
#lpSubsidy .ovSect__cmt li {
  list-style-type: none;
  counter-increment: cnt;
}
#lpSubsidy .ovSect__cmt li::before {
  content: "※" counter(cnt) "　";
  display: inline-block;
  margin-left: -3em; /* サイトに合せて調整 */
  width: 3em; /* サイトに合せて調整 */
}
#lpSubsidy .rmSect {
  width: 1200px;
  margin: 0 auto;
}
#lpSubsidy .rmSect__ttl {
  background-color: #f39800;
  color: #ffffff;
  font-weight: 600;
  letter-spacing: 5px;
  text-align: center;
  padding: 8px;
  margin-bottom: 24px;
}
#lpSubsidy .rmSect .rmBlock {
  margin-bottom: 24px;
}
#lpSubsidy .rmSect .rmBlock h4 {
  color: #ffffff;
  font-weight: 600;
  letter-spacing: 5px;
  text-align: center;
  padding: 8px;
  width: 40%;
  margin: 0 auto 16px;
}
#lpSubsidy .rmSect .rmBlock__ttlKc {
  background-color: #ffba4b;
}
#lpSubsidy .rmSect .rmBlock__ttlBt {
  background-color: #f4aed4;
}
#lpSubsidy .rmSect .rmBlock__ttlTl {
  background-color: #7ba7ff;
}
#lpSubsidy .rmSect .rmBlock__ttlWs {
  background-color: #95d7a3;
}
#lpSubsidy .rmSect .rmBlock__cont {
  text-align: center;
  position: relative;
}
#lpSubsidy .rmSect .rmBlock__contTtl {
  position: absolute;
  left: 4%;
  top: -2%;
}
#lpSubsidy .lkSect {
  margin: 0 auto;
  text-align: center;
  width: 1200px;
  padding-bottom: 96px;
}
#lpSubsidy .lkSect .custom-btn {
  width: 1100px;
  height: 80px;
}
#lpSubsidy .lkSect .btn-6 span {
  display: grid;
  place-items: center;
  font-size: 2rem;
}

/* ---------------------------         子育てエコホーム支援事業用          -------------------------------*/
#lpHousing2024 {
  width: 1200px;
  margin: 0 auto;
  padding: 0 50px;
}
@media (max-width: 770px) {
  #lpHousing2024 {
    width: 100%;
    padding: 0;
  }
}
#lpHousing2024 sup {
  vertical-align: super;
  font-size: smaller;
}
#lpHousing2024 p {
  margin: 0px;
}

.lpHousing2024__mainBanner {
  margin-bottom: 56px;
}
@media (max-width: 770px) {
  .lpHousing2024__mainBanner {
    margin-bottom: 24px;
  }
}

.kosodateEco__title {
  text-align: center;
  font-size: 48px !important;
  background-color: #14ae67;
  color: #ffffff;
  padding: 8px !important;
  margin-bottom: 40px !important;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900 !important;
}
@media (max-width: 770px) {
  .kosodateEco__title {
    font-size: 24px !important;
    margin-bottom: 16px !important;
  }
}
.kosodateEco__img {
  margin-bottom: 56px;
}
@media (max-width: 770px) {
  .kosodateEco__img {
    margin-bottom: 24px;
  }
}
.kosodateEco .kosodateEcoCont {
  display: flex;
  gap: 16px;
  margin-bottom: 40px;
}
@media (max-width: 770px) {
  .kosodateEco .kosodateEcoCont {
    flex-flow: column;
    margin-bottom: 16px;
  }
}
.kosodateEco .kosodateEcoCont__leftArea {
  width: 50%;
  background-color: #14ae67;
  border-radius: 15px;
  padding: 24px;
}
@media (max-width: 770px) {
  .kosodateEco .kosodateEcoCont__leftArea {
    width: 100%;
  }
}
.kosodateEco .kosodateEcoCont__leftArea h4 {
  color: #ffffff;
  text-align: center;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock {
  background-color: #ffffff;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock hr {
  width: 90%;
  text-align: center;
  margin: 8px auto;
  background-color: #14ae67;
  height: 2px;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock h5 {
  text-align: center;
  background-color: #cce8e2;
  font-weight: normal;
  padding: 8px !important;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock__unit {
  display: flex;
  gap: 32px;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock__unitLeft {
  width: 40%;
  padding: 0 16px;
  line-height: 1.4;
  font-size: 12px;
}
.kosodateEco .kosodateEcoCont .kosodateEcoBlock__unitRight {
  width: 60%;
  font-size: 24px;
  line-height: normal;
  font-weight: 600;
  text-align: center;
}
@media (max-width: 770px) {
  .kosodateEco .kosodateEcoCont .kosodateEcoBlock__unitRight {
    font-size: 14px;
  }
}
.kosodateEco .kosodateEcoCont__rightArea {
  width: 50%;
  background-image: url("https://www.rizaim.biz/img/lp/subsidy/ovSect__contRt-img.jpg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position-x: right;
  background-position-y: bottom;
}
@media (max-width: 770px) {
  .kosodateEco .kosodateEcoCont__rightArea {
    width: 100%;
  }
}
.kosodateEco .kosodateEcoCont__rightAreaimg {
  position: absolute;
}
.kosodateEco .kosodateEcoCont__coment {
  font-size: 80%;
  padding: 20px;
  color: #ffffff;
  margin-bottom: 0;
}
.kosodateEco .kosodateEcoCont__coment li {
  list-style-type: none;
  counter-increment: cnt;
}
.kosodateEco .kosodateEcoCont__coment li::before {
  content: "※" counter(cnt) "　";
  display: inline-block;
  margin-left: -3em; /* サイトに合せて調整 */
  width: 3em; /* サイトに合せて調整 */
}
.kosodateEco .kosodateEcoCont .kosodateEcoRightBlock {
  display: flex;
  gap: 24px;
}
.kosodateEco .kosodateEcoCont .kosodateEcoRightBlock__leftArea {
  color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  box-shadow: 5px 5px 10px 0 rgba(0, 0, 0, 0.1);
  padding: 20px;
  border-radius: 20px;
  width: 40%;
  line-height: 1.4;
  text-align: center;
  background-color: #14ae67;
}
.kosodateEco .kosodateEcoCont .kosodateEcoRightBlock__rightArea {
  width: 60%;
  background-color: #e74848;
  color: #ffffff;
  border-radius: 10px;
  padding: 16px;
  height: 72px;
  line-height: 1.4;
}
.kosodateEco .targetConstruction__attentionText {
  font-size: 40px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #14ae67;
  text-align: center;
  line-height: 0.8;
  margin-bottom: 40px !important;
}
@media (max-width: 770px) {
  .kosodateEco .targetConstruction__attentionText {
    font-size: 20px;
    line-height: 1.2;
    margin-bottom: 16px !important;
  }
}
.kosodateEco .targetConstruction__strongText {
  font-size: 80px;
}
@media (max-width: 770px) {
  .kosodateEco .targetConstruction__strongText {
    font-size: 54px;
  }
}
.kosodateEco .targetConstruction__coment {
  font-size: 80%;
  padding: 20px;
}
.kosodateEco .targetConstruction__coment li {
  list-style-type: none;
  counter-increment: cnt;
}
.kosodateEco .targetConstruction__coment li::before {
  content: "※" counter(cnt) "　";
  display: inline-block;
  margin-left: -3em; /* サイトに合せて調整 */
  width: 3em; /* サイトに合せて調整 */
}
.kosodateEco .targetConstruction sup {
  color: #000000;
  font-weight: 400;
  font-size: 18px !important;
}

.guideLinkArea {
  display: flex;
  row-gap: 16px;
  margin-bottom: 56px;
}
@media (max-width: 770px) {
  .guideLinkArea {
    margin-bottom: 24px;
  }
}
.guideLinkArea__left {
  width: 50%;
}
.guideLinkArea__right {
  width: 50%;
}

.combinationExample__title {
  text-align: center;
  font-size: 48px !important;
  background-color: #ffe46d;
  color: #ffffff;
  padding: 8px !important;
  margin-bottom: 40px !important;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900 !important;
  text-shadow: 2px 2px 1px #000000, -2px 2px 1px #000000, 2px -2px 1px #000000, -2px -2px 1px #000000, 2px 0px 1px #000000, 0px 2px 1px #000000, -2px 0px 1px #000000, 0px -2px 1px #000000;
}
@media (max-width: 770px) {
  .combinationExample__title {
    font-size: 24px !important;
    margin-bottom: 16px !important;
  }
}
.combinationExample__downArrow {
  margin-bottom: 40px;
}
@media (max-width: 770px) {
  .combinationExample__downArrow {
    margin-bottom: 16px;
  }
}
.combinationExample__subHeading {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900 !important;
  font-size: 40px !important;
}
@media (max-width: 770px) {
  .combinationExample__subHeading {
    font-size: 24px !important;
  }
}
.combinationExample__subHeading.--green {
  color: #14ae67;
}
.combinationExample__subHeading.--red {
  color: #e4655c;
}
.combinationExample__case {
  margin-bottom: 40px;
}
@media (max-width: 770px) {
  .combinationExample__case {
    margin-bottom: 16px;
  }
}

.kosodateBtn01 {
  display: block;
  text-align: center;
  vertical-align: middle;
  text-decoration: none;
  width: 90%;
  margin: auto;
  padding: 3rem 1rem;
  transition: 0.5s;
  border-radius: 30px;
  font-size: 32px;
  line-height: 1.4;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
}
@media (max-width: 770px) {
  .kosodateBtn01 {
    font-size: 14px;
  }
}
.kosodateBtn01.--red {
  border: 2px solid #ea504a;
  background: #ea504a;
  color: #fff;
}
.kosodateBtn01.--red:hover {
  color: #ea504a;
  background: #fff;
  text-decoration: none;
}
.kosodateBtn01.--blue {
  border: 2px solid #3da4dd;
  background: #3da4dd;
  color: #fff;
}
.kosodateBtn01.--blue:hover {
  color: #3da4dd;
  background: #fff;
  text-decoration: none;
}

.lkSect {
  margin: 0 auto;
  text-align: center;
  width: 1200px;
  padding-bottom: 96px;
}
.lkSect .custom-btn {
  width: 1100px;
  height: 80px;
}
.lkSect .btn-6 span {
  display: grid;
  place-items: center;
  font-size: 2rem;
}

/*-------------- デフォルトの変更 -------------- */
.footer_menu li {
  margin-bottom: 8px;
}

/* --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------*/
@media screen and (max-width: 770px) {
  /* --------------- ヘッダー用 --------------- */
  #header_content .item {
    height: initial;
  }
  #header {
    -webkit-backdrop-filter: blur(3px);
            backdrop-filter: blur(3px);
  }
  .dp-footer-bar {
    -webkit-backdrop-filter: blur(3px);
            backdrop-filter: blur(3px);
    z-index: 99;
  }
  #global_menu {
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.85);
    top: 0;
  }
  #global_menu .menu {
    width: 250px;
    margin: 200px auto;
  }
  #global_menu a {
    background: none;
  }
  #global_menu ul ul a {
    background: none;
  }
  a.menu_button.active:hover:before,
a.menu_button.active:before {
    content: "\f00d";
    font-family: "Font Awesome 5 Free";
    font-weight: 600;
  }
  a.menu_button:hover:before,
a.menu_button:before {
    content: "\f0c9";
    font-family: "design_plus";
    color: #888888;
  }
  a.menu_button:hover {
    background-color: transparent;
  }
  a.menu_button.active {
    border-left: none;
  }
  /* --------------- フッター用 --------------- */
  .contMargin {
    height: 0;
  }
  #copyright {
    width: calc(100% + 10px);
  }
  .home #footer_top {
    position: relative;
    bottom: 24px;
  }
  .home .dp-footer-bar {
    bottom: 60px;
  }
  .home #footer_bottom {
    position: relative;
  }
  .home #return_top {
    display: flex;
    width: 100%;
    bottom: 0 !important;
  }
  .home #return_top ul {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    width: 100%;
  }
  .home #return_top ul li {
    background-color: #0ea5e9;
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px #ffffff solid;
    text-align: center;
    line-height: 1.4;
    padding-top: 5px;
  }
  .home #return_top ul li:hover {
    background-color: #e8a02b;
  }
  .home #return_top ul li a {
    display: block;
    font-size: 1.1rem;
    position: relative;
    width: auto;
    height: auto;
    color: #ffffff;
  }
  .home #return_top ul li a::before {
    content: "";
  }
  .home #return_top ul li a i {
    font-size: 24px;
  }
  .home .footerMargin {
    display: block;
    height: 60px;
    width: 100%;
  }
  /* ---------------------------         front-page用          -------------------------------*/
  .exConst {
    padding: 32px 0 48px;
    margin-bottom: 64px;
  }
  .exConst #index_project {
    padding: 0 25px;
    margin: 0 auto 48px;
    width: 100%;
  }
  .exConst #index_project .catchphrase {
    width: 100%;
    margin: 0 0 22px 0;
    position: relative;
  }
  .exConst #index_project .catchphrase ::-webkit-scrollbar-thumb {
    background: #454552;
    border-radius: 100px;
    width: 130px;
  }
  .exConst #index_project .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin-right: 0;
    display: block;
    text-align: center;
  }
  .exConst #index_project .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .exConst #index_project .pjLinkwrap {
    width: 100%;
    position: relative;
  }
  .exConst #index_project .index_project_link {
    margin: 20px auto 0;
    position: relative;
    right: 0;
  }
  #index_news .index_news_list {
    margin-bottom: 16px;
  }
  .onlineInfo {
    width: 100%;
    margin: 32px 0 48px;
    padding: 30px 20px 0;
    flex-direction: column-reverse;
  }
  .onlineInfo__right {
    width: 100%;
  }
  .onlineInfo__right__banner {
    margin: 40px 0;
    gap: 16px;
  }
  .onlineInfo__right img {
    width: 100%;
  }
  .onlineInfo__left {
    width: 100%;
    margin-top: 30px;
  }
  .onlineInfo__left__qr {
    display: none;
  }
  .onlineInfo__ttl {
    margin-bottom: 30px;
  }
  .onlineInfo__ttl span {
    font-size: 1.2em;
  }
  .headerInfo {
    display: none;
  }
  .headerCp {
    display: none;
  }
  .prjHead {
    font-size: 1.5em;
    margin-top: 0px;
    background-size: 125%;
  }
  .slide-items {
    width: 100%;
    min-width: 100%;
    margin: 64px auto !important;
    padding: 0;
  }
  .notionArea {
    width: 100%;
    height: auto;
    margin-bottom: 64px;
    grid-template-columns: 100%;
  }
  .notionArea .notionCont {
    display: block;
  }
  .notionArea .notionCont__inner {
    width: 100%;
    padding: 0 25px 40px;
  }
  .notionArea__ttl {
    font-size: 2.5rem;
  }
  .notionArea__catch {
    font-size: 4rem;
  }
  .notionArea .notionImg__inner {
    height: 300px;
    width: 90%;
    margin: 0 auto;
  }
  .fpReview {
    width: 100%;
    margin-bottom: 64px;
  }
  .rcBanner {
    margin: 0 0 64px;
    width: 100%;
    padding: 0 20px;
  }
  .rcBanner img {
    width: 100%;
  }
  .fpAccess {
    margin-bottom: 64px;
  }
  .fpAccess .catchphrase {
    width: 100%;
  }
  .fpAccess .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  .fpAccess .catchphrase h3 {
    max-inline-size: none;
  }
  .fpAccess .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .fpAccess__list {
    max-width: 100%;
    padding: 0 25px;
  }
  .fpAccess__list li {
    padding: 0.5em 0.5em 0.5em 0.5em;
  }
  .pickupArea {
    margin-bottom: 64px;
    padding: 32px 0;
  }
  .pickupArea .catchphrase {
    width: 100%;
  }
  .pickupArea .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  .pickupArea .catchphrase h3 {
    max-inline-size: none;
  }
  .pickupArea .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .pickupArea__listItem {
    width: 100%;
    height: auto;
    margin-bottom: 40px;
  }
  .pickupArea__listItem img {
    position: relative;
    width: 100%;
    height: 300px;
    border-bottom: none;
  }
  .pickupArea__listItem .pickupArea__lDetail {
    position: relative;
    width: 100%;
    height: auto;
    top: 0;
  }
  .pickupArea__listItem:nth-child(odd) .pickupArea__lDetail {
    left: 0;
    padding: 25px 25px 64px;
  }
  .pickupArea__listItem:nth-child(odd) .pickupArea__btn {
    right: 0;
    display: flex;
    justify-content: flex-end;
  }
  .pickupArea__listItem:nth-child(even) .pickupArea__lDetail {
    right: 0;
    padding: 25px 25px 64px;
  }
  .pickupArea__listItem:nth-child(even) .pickupArea__btn {
    left: 0;
    display: flex;
    justify-content: flex-end;
  }
  .pickupArea__btn {
    position: relative;
    bottom: -16px;
  }
  .pickupArea__list {
    width: 100%;
  }
  .pickupArea__list .pickupItem {
    flex-direction: column;
  }
  .pickupArea__list .pickupItem__img {
    width: 100%;
    padding: 48px;
  }
  .pickupArea__list .pickupItem__img img {
    width: 100%;
  }
  .pickupArea__list .pickupItem__point {
    top: 384px;
    right: 16px;
  }
  .pickupArea__list .pickupItem__point img {
    width: 80px;
  }
  .pickupArea__list .pickupItem .pickupCont {
    width: 100%;
    padding-bottom: 48px;
    padding-top: 48px;
  }
  .pickupArea__list .pickupItem .pickupCont__note {
    padding-bottom: 24px;
  }
  .pickupArea__list .pickupItem:nth-child(even) {
    flex-direction: column-reverse;
  }
  .bannerArea {
    width: 100%;
    margin-bottom: 64px;
  }
  .bannerArea .bannerList {
    grid-template-columns: 1fr;
  }
  .mainBanner {
    width: 100%;
    margin-bottom: 64px;
    padding: 0 20px;
  }
  .mainBanner img {
    width: 100%;
  }
  .backGround {
    display: none !important;
  }
  #index_news {
    padding: 0 20px !important;
    margin-bottom: 64px;
  }
  #index_news .catchphrase .curtainLefttoRight {
    margin-bottom: 0;
  }
  #index_news .catchphrase .desc {
    text-align: center;
  }
  #index_project {
    padding: 0 20px !important;
  }
  .fontAnime:before {
    padding-top: 100%; /* 高さを幅の75%に固定 */
  }
  .index3Box {
    margin-bottom: 48px;
  }
  .index3Box__wrap {
    grid-template-columns: 1fr;
    width: 100%;
    padding: 40px 25px;
    margin-bottom: 0;
  }
  .index3Box__block {
    margin-bottom: 48px;
  }
  .index3Box .ovArea {
    width: 100%;
    margin-bottom: 24px;
    padding-top: 80px;
  }
  .index3Box .ovArea h3 {
    margin-bottom: 64px;
    line-height: 1.4;
  }
  .subGmenu {
    display: inherit;
    background-color: #333333;
  }
  .subGmenu img {
    max-width: 100%;
  }
  .subGmenu a {
    padding: 15px !important;
    height: 160px !important;
  }
  .infoArea {
    display: none;
  }
  .informationArea {
    display: none;
  }
  .planArea {
    width: 100%;
    padding: 0 25px;
    margin: 0 auto 64px;
  }
  .planArea .catchphrase {
    margin: 0 0 22px 0;
    position: relative;
  }
  .planArea .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin-right: 0;
    display: block;
    text-align: center;
  }
  .planArea .catchphrase .desc {
    font-size: 14px;
    display: block;
    text-align: center;
  }
  .planArea__planUl {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
  }
  .planArea__planUl li {
    height: 100%;
  }
  .planArea__planUl li img {
    max-width: 100%;
  }
  .planArea__planUl li div {
    padding-top: 8px;
    position: inherit;
    width: 100%;
    height: 72px;
    box-shadow: none;
  }
  .planArea__planUl li div span::before {
    top: 53px;
  }
  .planArea__planUl2 {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    width: 100%;
  }
  .planArea__planUl2 li {
    height: 100%;
  }
  .planArea__planUl2 li img {
    max-width: 100%;
  }
  .planArea__planUl2 li div {
    padding-top: 8px;
    position: inherit;
    width: 100%;
    height: 72px;
    box-shadow: none;
  }
  .planArea__planUl2 li div span::before {
    top: 53px;
  }
  .planArea__costDl {
    width: 100%;
  }
  .planArea__cmt {
    width: 100%;
    padding: 20px 1em 0 2em;
  }
  .planArea__subTtl {
    font-size: clamp(2rem, 3.1209362809vw, 2.4rem);
  }
  .supArea {
    margin-bottom: 64px;
  }
  .supArea .catchphrase {
    width: 100%;
  }
  .supArea .catchphrase .headline {
    font-size: 26px !important;
    line-height: 1.5;
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  .supArea .catchphrase h3 {
    max-inline-size: none;
  }
  .supArea .catchphrase .desc {
    display: block;
    text-align: center;
  }
  .supArea img {
    width: 90%;
  }
  .supArea__dlBox {
    width: 100%;
    padding: 0 25px;
  }
  .supArea__dlKyoto {
    gap: 5px;
    flex-wrap: wrap;
    font-size: 12px;
  }
  .supArea__dlShiga {
    gap: 5px;
    flex-wrap: wrap;
    font-size: 12px;
    flex-direction: inherit;
  }
  .supArea__cmt {
    width: 100%;
    padding: 20px 35px;
  }
  .cfBanner {
    display: none;
  }
  /* ---------------------------         お問い合わせ用          -------------------------------*/
  .contactArea {
    display: none;
  }
  .verticalBanner {
    display: none;
  }
  .form2 dl {
    flex-flow: column;
  }
  .FormBox {
    flex-direction: column;
  }
  .FormArea {
    padding: 20px;
  }
  .FormArea .form {
    padding: 10px;
  }
  .FormArea .form dl {
    margin-bottom: 0px;
  }
  .FormArea .form dt {
    width: 100%;
    flex-basis: 100%;
  }
  .FormArea .form dd {
    width: 100%;
    flex-basis: 100%;
  }
  .telArea {
    padding: 20px;
  }
  /* ---------------------------         施行の流れ用          -------------------------------*/
  .mainVisual {
    width: 100%;
  }
  .flowCont {
    width: auto;
    display: grid;
    grid-template: "... ...... ... ...... ..." 10px "... fitem1 ... fitem2 ..." "... fitem1 ... ...... ..." 10px "... fitem1 ... fitem3 ..." "... fitem1 ... ...... ..." 10px "... fitem1 ... fitem4 ..." "... fitem1 ... ...... ..." 10px "... fitem1 ... fitem5 ..." "... fitem1 ... ...... ..." 10px "... fitem1 ... fitem6 ..." "... fitem1 ... ...... ..." 10px "... fitem1 ... fitem7 ..." "... fitem1 ... ...... ..." 10px "... fitem8 ... fitem9 ..." "... fitem8 ... ...... ..." 10px "... fitem8 ... fitema ..." "... fitem8 ... ...... ..." 10px "... fitem8 ... fitemb ..." "... fitem8 ... ...... ..." 10px "... fitem8 ... fitemc ..." "... fitem8 ... ...... ..." 10px "... fitem8 ... fitemd ..." "... fitem8 ... ...... ..." 10px "... fitem8 ... fiteme ..." "... fitem8 ... ...... ..." 10px "... fitemf ... fitemg ..." "... fitemf ... ...... ..." 10px "... fitemf ... fitemh ..." "... fitemf ... ...... ..." 10px/auto 40px 20px 1fr auto;
  }
  .flowCont img {
    width: 100%;
  }
  .fItem1,
.fItem8,
.fItemf {
    padding: 30px 0px;
  }
  .fItemj,
.fItemk,
.fIteml,
.fItemm,
.fItemn,
.fItemi {
    display: none;
  }
  .flowDetail__cont {
    width: 100%;
  }
  /* ---------------------------         工事内容説明用          -------------------------------*/
  .explan {
    width: 100%;
    grid-template: "... ...... ...... ...... ..." 80px "... explaT explaT explaT ..." "... explaF ...... explaC ..." 1fr "... explaI explaI explaI ..." 1fr "... ...... ...... ...... ..." 10px/auto 80px 16px 1fr auto;
  }
  .explan__face {
    display: flex;
    align-items: center;
  }
  .explan__img {
    width: 100%;
  }
  .explanDetail {
    flex-direction: column;
  }
  .explanDetail__img {
    width: 100%;
  }
  .explanDetail__slate {
    display: none;
  }
  .explanDetail p {
    padding-right: initial;
  }
  .constructionList {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .constructionList li h3 {
    text-align: center;
    line-height: 2.4;
  }
  .constructionList li img {
    padding: 0 24px 16px;
  }
  .constructionList li p {
    padding: 0 24px;
    line-height: 1.6;
  }
  .constructionList li i {
    display: none;
  }
  .constructionList__step {
    background-color: #0ea5e9;
    color: #ffffff;
    padding: 4px 24px;
    font-size: 1.4rem;
  }
  /* ---------------------------         点検・見積り依頼はこちら用          -------------------------------*/
  .explainImg {
    display: grid;
    grid-template: "... ...... ... ...... ..." 10px "... eitem1 ... eitem2 ..." "... eitem3 ... eitem4 ..." "... ...... ... ...... ..." 10px/auto 1fr 0px 1fr auto;
  }
  .roofBacont1 {
    flex-direction: column;
  }
  .roofBacont1__left {
    width: 100%;
  }
  .roofBacont1__right {
    width: 100%;
  }
  .roofBacont2 {
    flex-direction: column-reverse;
  }
  .roofBacont2__left {
    width: 100%;
  }
  .roofBacont2__right {
    width: 100%;
  }
  .roofBacont3 {
    flex-direction: column;
  }
  .roofBacont3__left {
    width: 100%;
  }
  .roofBacont3__right {
    width: 100%;
  }
  .emphasisBtn a span {
    padding: 18px 30px;
  }
  .emphasisBtn a span:after {
    padding: 18px 30px;
  }
  /* ---------------------------         こどもみらい住宅支援事業用          -------------------------------*/
  #lpSubsidy {
    padding: 0 16px;
  }
  #lpSubsidy .ttlSect {
    width: 100%;
  }
  #lpSubsidy .ttlSect__cont {
    flex-direction: column;
    align-items: center;
  }
  #lpSubsidy .ttlSect__cmt {
    width: 100%;
    margin: 0 0 24px;
  }
  #lpSubsidy .ovSect {
    width: 100%;
  }
  #lpSubsidy .ovSect__cont {
    flex-direction: column;
  }
  #lpSubsidy .ovSect__contLt {
    width: 100%;
  }
  #lpSubsidy .ovSect__contRt {
    width: 100%;
    height: 300px;
  }
  #lpSubsidy .ovSect__contBlockUnit {
    gap: 0;
  }
  #lpSubsidy .ovSect__contBlockUnitRt {
    font-size: initial;
  }
  #lpSubsidy .rmSect {
    width: 100%;
  }
  #lpSubsidy .rmSect .rmBlock h4 {
    width: 60%;
  }
  #lpSubsidy .lkSect {
    width: 100%;
  }
  #lpSubsidy .lkSect .custom-btn {
    width: 100%;
  }
}
/* ------------------------------------------------------------------ トップページ文字サイズ変更（PC） ---------------------------------------------------------------------------------------------------------------------------*/
@media screen and (min-width: 771px) {
  #index_news .catchphrase .headline,
#planArea .catchphrase .headline,
#index_project .catchphrase .headline,
.pickupArea .catchphrase .headline,
.supArea .catchphrase .headline,
#fpAccess .catchphrase .headline,
#index_blog .catchphrase .headline {
    font-size: 54px !important;
  }
  #index_news .catchphrase .desc,
#planArea .catchphrase .desc,
#index_project .catchphrase .desc,
.pickupArea .catchphrase .desc,
.supArea .catchphrase .desc,
#fpAccess .catchphrase .desc,
#index_blog .catchphrase .desc {
    font-size: 26px !important;
  }
  .pc #header .headerInfo__mail {
    width: 150px;
    height: 72px;
    background: #ef4444;
    color: #ffffff;
    border-radius: 5px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all 0.5s ease;
    font-size: 18px;
    flex-direction: column;
  }
  .pc #header #global_menu .menu-item a {
    font-size: 1.6rem;
  }
  .pc #header #global_menu .menu-item ul.sub-menu li a {
    font-size: 1.3rem;
  }
  .pc #header .headerInfo__mail, .pc #header .headerInfo__tol {
    font-size: 16px;
  }
  .index_news_list .headline,
.index_news_list .archive_link {
    font-size: 16px;
  }
  .index_news_list ol a .entry-date,
.index_news_list ol a .title {
    font-size: 16px;
  }
  .planArea__subTtl {
    font-size: 32px;
  }
  .planArea__costDl dt {
    font-size: clamp(1.6rem, 2.0833333333vw, 2.2rem);
  }
  .exConst #project_list li .project_catch {
    font-size: 3rem;
  }
  .exConst #project_list .projectCat {
    font-size: 1.8rem;
  }
  .exConst #project_list .title2 {
    font-size: 16px !important;
    height: 106px;
  }
  .notionArea__catch {
    font-size: 7rem;
  }
  .notionArea .notionCont__ttlup, .notionArea .notionCont__ttlud {
    font-size: clamp(3.2rem, 2.571429vw, 3.7rem);
  }
  .notionArea .notionCont__inner {
    width: clamp(580px, 30.833333vw, 680px);
  }
  .notionArea .notionCont__inner p {
    font-size: large;
  }
  .pickupArea .basicBox {
    font-size: 1.8rem;
  }
  .pickupArea__list .pickupItem .pickupCont h4 {
    font-family: "Noto Serif JP", serif;
    font-size: 2.4rem;
  }
  .pickupArea__list .pickupItem .pickupCont p {
    font-size: large;
  }
  .pickupArea__list .pickupItem .pickupCont__wrap {
    width: 80%;
  }
  .supArea__dlBox {
    font-size: 2rem;
  }
  .supArea__cmt {
    font-size: 100%;
  }
  .fpAccess__list li {
    font-size: clamp(12px, 3.2vw, 18px);
  }
  .fpAccess__cont {
    font-size: 20px;
  }
  #blog_list .title {
    font-size: 20px;
  }
  .onlineInfo__left__qr {
    font-size: 1.8rem;
  }
  .index3Box .ovArea h3 {
    font-size: 3rem;
  }
  .index3Box .ovArea p {
    font-size: 108%;
  }
  .index3Box__block h3 {
    font-size: 2rem;
  }
  .index3Box__block p {
    font-size: 110%;
    text-align: left;
  }
  #footer_address {
    font-size: 15px;
  }
  #footer_menu {
    width: 624px;
  }
  .footer_menu li {
    font-size: 15px;
  }
  .footer_menu li:first-child a, .footer_menu li:only-child a {
    font-size: 18px;
  }
  #footer_menu.footer_menu_num3 .footer_menu {
    margin: 0 32px 0 0;
    width: 184px;
  }
  #footer_menu_widget_area {
    width: 900px;
  }
  /* 親要素（variableParent）によってフォントサイズ（variableChild）を変える　*/
  .variableParent {
    border: 1px solid black; /* 視覚的な確認のための枠線 */
    width: 300px; /* 初期の親要素の幅 */
    white-space: normal; /* 折り返しを許可 */
  }
  .variableChild {
    font-size: 1em; /* 初期の文字サイズ */
    display: inline-block; /* テキストが折り返されるようにするためにインラインブロックを使用 */
  }
}
/*# sourceMappingURL=rsstyle.css.map */