@charset "UTF-8";
strong {
  font-weight: 700;
}

.header-structure {
  position: relative;
}
.header-structure:before {
  width: 185px;
  height: 181px;
  content: "";
  display: inline-block;
  position: absolute;
  top: 0px;
  z-index: 10;
}
.header-structure.kodawari-1:before {
  background-image: url("../misc/icon_kodawari1.png");
}
.header-structure.kodawari-2:before {
  background-image: url("../misc/icon_kodawari2.png");
}
.header-structure.kodawari-3:before {
  background-image: url("../misc/icon_kodawari3.png");
}
.header-structure.kodawari-4:before {
  background-image: url("../misc/icon_kodawari4.png");
}
.header-structure.kodawari-5:before {
  background-image: url("../misc/icon_kodawari5.png");
}
.header-structure.kodawari-6:before {
  background-image: url("../misc/icon_kodawari6.png");
}

.title-structure {
  font-weight: 700;
  border-bottom: 2px dashed #000;
  padding-bottom: 0.2em;
  margin-bottom: 0.2em;
  margin-left: 45px;
  padding-left: 150px;
  position: relative;
}

.lead-structure {
  padding-left: 195px;
}
.dl-madori img {
  display: block;
  margin-bottom: 0.3em;
}

.title-madori-detail {
  color: #D83500;
  font-weight: 700;
  margin-bottom: 0.3em;
  line-height: 1.3;
  margin-bottom: 0.4em;
}
.title-madori-detail:before {
  content: "";
  display: inline-block;
  margin-right: 0.3em;
  height: 34px;
  width: 34px;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  position: relative;
  top: 7px;
}
.title-madori-detail.number-1:before {
  background-image: url("../new-plan/structure/img/madori_01.png");
}
.title-madori-detail.number-2:before {
  background-image: url("../new-plan/structure/img/madori_02.png");
}
.title-madori-detail.number-3:before {
  background-image: url("../new-plan/structure/img/madori_03.png");
}
.title-madori-detail.number-4:before {
  background-image: url("../new-plan/structure/img/madori_04.png");
}
.title-madori-detail.number-5:before {
  background-image: url("../new-plan/structure/img/madori_05.png");
}
.title-madori-detail.number-6:before {
  background-image: url("../new-plan/structure/img/madori_06.png");
}
.title-madori-detail.number-7:before {
  background-image: url("../new-plan/structure/img/madori_07.png");
}
.title-madori-detail.number-8:before {
  background-image: url("../new-plan/structure/img/madori_08.png");
}
.title-madori-detail.number-9:before {
  background-image: url("../new-plan/structure/img/madori_09.png");
}

.title-structure-2 {
  color: #FFF;
  background-color: #F0883C;
  border-radius: 100px;
  padding: 3px 30px;
  margin-bottom: 15px;
  line-height: 1.3;
}

.title-structure-graph {
  color: #F0883B;
  position: relative;
  padding-left: 85px;
  line-height: 1.3;
  font-weight: 700;
}
.title-structure-graph:before {
  position: absolute;
  left: 0;
  top: -10px;
  content: "";
  display: inline-block;
  width: 81px;
  height: 81px;
  background-image: url("../new-plan/structure/img/icon_01.png");
}

.with-obj-energy {
  position: relative;
}

.title-sickhouse {
  color: #3F1F00;
  font-weight: 700;
  margin-bottom: 0.4em;
}

.title-iezukuri {
  background-color: #FFF;
  border-radius: 100px;
  line-height: 1.3;
  font-weight: 700;
  padding: 3px 35px;
  margin-bottom: 25px;
}
.title-tokutyou{
  background-color: #854E03;
  border-radius: 100px;
  line-height: 1.3;
  font-weight: 400;
  color: #fff;
  padding: 3px 35px;
  margin-bottom: 25px;
}
.image-frame-thin {
  padding: 5px;
  background-color: #FFF;
}

.fig-safe {
  position: relative;
}
.fig-safe img {
  vertical-align: bottom;
}

.caption-safe {
  position: absolute;
  bottom: 0;
  left: 0;
  background-color: rgba(102, 76, 0, 0.8);
  padding: 5px;
  line-height: 1.3;
  color: #FFF;
}

.title-safe-sub {
  color: #3F1F00;
  font-weight: 700;
  margin-bottom: 0.5em;
}

.title-safe {
  padding: 3px 25px;
  border-radius: 100px;
  background-color: #F0883C;
  color: #fff;
  text-align: center;
  margin-bottom: 25px;
}

.fig-safety {
  background: url("../new-plan/structure/img/bg_05.png") left top no-repeat;
  text-align: right;
}
.fig-safety img {
  vertical-align: bottom;
}

.title-quality {
  text-align: center;
  color: #3F1F00;
  background-color: #fff;
  border-radius: 100px;
  padding: 3px 25px;
  margin-bottom: 1em;
  line-height: 1.3;
}

.fig-quality h4 {
  font-weight: 700;
}

.title-mama-big {
  font-family: "Times New Roman", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "HG明朝B", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  color: #FF7272;
  text-align: center;
  margin-bottom: 0.5em;
}

.with-obj-mama {
  background: url("../new-plan/structure/img/catch_01.png") right top no-repeat;
}

.caption-graph-mama {
  margin-bottom: -10px;
  position: relative;
}
.caption-graph-mama img {
  vertical-align: bottom;
}

.row-outro {
  
}

.list-plane{
  margin-bottom: 1.5em;
}

@media print, screen and (min-width: 741px){
  .header-structure{
    margin-bottom: 75px;
  }
  .header-structure{
    padding-top: 45px;
  }
  .title-structure{
    font-size: 35px;
  }
  .title-structure:before{
    position: absolute;
    content: url("../new-plan/structure/img/obj_02.png");
    right: 15px;
    top: 12px;
  }
  .lead-structure{
    font-size: 25px;
  }
  .col-madori-map{
    background: url("../new-plan/structure/img/obj_01.png") center bottom no-repeat;
    width: 47%;
    float: right;
    padding-bottom: 265px;
  }
  .cols.col-madori-detail{
    width: 49%;
    float: left;
  }
  .dl-madori{
    zoom: 1;
    width: 47%;
    float: left;
    margin-left: 3%;
    margin-bottom: 24px;
  }
  .dl-madori:before, .dl-madori:after{
    content: "";
    display: table;
  }
  .dl-madori:after{
    clear: both;
  }
  .dl-madori:first-child{
    margin-left: 0;
  }
  .dl-madori:nth-of-type(2n+1){
    margin-left: 0;
    clear: both;
  }
  .title-madori-detail{
    font-size: 22px;
  }
  .title-madori-detail{
    white-space: nowrap;
  }
  .row-kodawari-2{
    background: url("../new-plan/structure/img/bg_02.png") left bottom no-repeat, url("../new-plan/structure/img/bg_01.png") left top no-repeat;
    padding-left: 356px;
  }
  .title-structure-2{
    font-size: 30px;
  }
  .row-grid-figure{
    margin-bottom: 45px;
  }
  .title-structure-graph{
    font-size: 22px;
  }
  .title-structure-graph{
    margin-bottom: 25px;
  }
  .with-obj-energy:before{
    background: url(../misc/obj_29.png) left top no-repeat;
    display: inline-block;
    content: "";
    height: 240px;
    width: 185px;
    background-size: 185px 240px;
    position: absolute;
    right: 0;
    top: -77px;
  }
  .row-sickhouse{
    margin-bottom: 45px;
  }
  .row-sickhouse .col-header-sickhouse{
    width: 37%;
    float: left;
  }
  .row-sickhouse .col-content-sickhouse{
    width: 58%;
    float: right;
    padding-top: 55px;
  }
  .title-sickhouse{
    font-size: 30px;
  }
  .row-iezukuri{
    padding-left: 357px;
    background: url("../new-plan/structure/img/bg_04.png") 155px bottom no-repeat, url("../new-plan/structure/img/bg_03.png") left top no-repeat;
  }
  .title-iezukuri{
    font-size: 30px;
  }
  .title-tokutyou{
    font-size: 26px;
  }
  .row-grid-iezukuri{
    margin-bottom: 45px;
  }
  .row-grid-iezukuri .grids.grid-5 {
    width: 48%;
    margin: 0.7% 1%;
  }
  .row-safe-intro{
    margin-bottom: 45px;
  }
  .row-safe-intro .col-grid{
    width: 54%;
    /*float: left;*/
	  margin: auto;
  }
  .row-safe-intro .col-desc{
    width: 45%;
    float: right;
  }
  .title-safe-sub{
    font-size: 28px;
  }
  .title-safe{
    font-size: 30px;
  }
  .fig-safety{
    padding-top: 35px;
    margin-bottom: 45px;
  }
  .row-safe .col-6{
    zoom: 1;
    width: 48%;
    float: left;
    margin-left: 2%;
    margin-bottom: 24px;
  }
  .row-safe .col-6:before, .row-safe .col-6:after{
    content: "";
    display: table;
  }
  .row-safe .col-6:after{
    clear: both;
  }
  .row-safe .col-6:first-child{
    margin-left: 0;
  }
  .row-safe .col-6:nth-of-type(2n+1){
    margin-left: 0;
    clear: both;
  }
  .row-safe .col-6 .photo{
    width: 198px;
    float: left;
    margin-right: 12px;
  }
  .row-safe .col-6 .content .title-safe-sub{
    font-size: 24px;
    line-height: 1.3;
  }
  .row-quality{
    margin-bottom: 45px;
  }
  .row-quality .col-photo{
    width: 37%;
    float: left;
  }
  .row-quality .col-content{
    width: 61%;
    float: right;
  }
  .title-quality{
    font-size: 28px;
  }
  .title-mama-big{
    font-size: 77px;
  }
  .with-obj-mama{
    padding-right: 485px;
    font-size: 18px;
    padding-bottom: 165px;
  }
  .row-graph-mama .col-graph-mama{
    zoom: 1;
    width: 46%;
    float: left;
    margin-left: 4%;
    margin-bottom: 45px;
  }
  .row-graph-mama .col-graph-mama:before, .row-graph-mama .col-graph-mama:after{
    content: "";
    display: table;
  }
  .row-graph-mama .col-graph-mama:after{
    clear: both;
  }
  .row-graph-mama .col-graph-mama:first-child{
    margin-left: 0;
  }
  .row-graph-mama .col-graph-mama:nth-of-type(2n+1){
    margin-left: 0;
    clear: both;
  }
  .row-outro{
    width: 995px;
    margin: auto;
    margin-bottom: 2.5em;
  }
  .shisutemu{
	font-size: 25px;
	margin-left: 30px;
	}
  .miryoku{
	font-size: 25px;
	}
  .text-nest {
		color: crimson;
		font-size: 30px;
		font-weight: bold;
	    margin-top: 40px;
	}
  .text-ene {
	    color: crimson;
		font-size: 22px;
		font-weight: bold;
	    margin-top: 10px;
	}
	.nest-icon img {
		margin-bottom: -35px;
		margin-top: 25px;
	}
	.nest-content {
		margin-bottom: -30px;
	}
    .notes-box {
		max-width: 680px;
        margin: 0 auto;
        text-align: center;
  }
	.nest-notes {
		display: inline-block;
		text-align: left;
	}
}

@media only screen and (max-width: 740px){
  .header-structure{
    margin-bottom: 15px;
  }
  .header-structure:before{
    width: 74px;
    height: 72.4px;
    background-size: 100%;
  }
  .title-structure{
    font-size: 20px;
  }
  .title-structure{
    margin-left: 15px;
    padding-left: 60px;
  }
  .lead-structure{
    font-size: 16px;
  }
  .lead-structure{
    padding-left: 75px;
  }
  .col-madori-map{
    margin-bottom: 24px;
  }
  .dl-madori{
    margin-bottom: 12px;
  }
  .dl-madori img{
    width: 100%;
  }
  .title-madori-detail{
    font-size: 16px;
  }
  .title-madori-detail:before{
    height: 20px;
    width: 20px;
    background-size: 100%;
  }
  .title-madori-detail:before{
    top: 5px;
  }
  .title-structure-2{
    font-size: 18px;
  }
  .row-grid-figure{
    margin-bottom: 25px;
  }
  .row-grid-figure .frids{
    margin-bottom: 12px;
  }
  .title-structure-graph{
    font-size: 16px;
  }
  .title-structure-graph{
    margin-bottom: 15px;
  }
  .title-structure-graph:before{
    top: -19px;
  }
  .with-obj-energy{
    margin-bottom: 25px;
  }
  .row-sickhouse{
    margin-bottom: 25px;
  }
  .row-sickhouse .col-header-sickhouse{
    width: 250px;
    margin: auto;
    margin-bottom: 1em;
  }
  .title-sickhouse{
    font-size: 18px;
  }
  .title-banner-str{
    margin-bottom: 1em;
  }
  .title-iezukuri{
    font-size: 20px;
    padding: 3px 20px;
  }
  .title-tokutyou{
    font-size: 16px;
  }
  .image-frame-thin{
    box-sizing: border-box;
    display: block;
  }
  .row-grid-iezukuri{
    margin-bottom: 25px;
  }
  .row-safe-intro{
    margin-bottom: 25px;
  }
  .caption-safe{
    font-size: 10px;
  }
  .title-safe-sub{
    font-size: 18px;
  }
  .title-safe{
    font-size: 20px;
  }
  .fig-safety{
    padding-top: 155px;
    background-size: 360px;
  }
  .row-safe{
    margin-bottom: 25px;
  }
  .row-safe .col-6{
    border-bottom: 1px solid #DDD;
    overflow: hidden;
    zoom: 1;
    margin-bottom: 1.5em;
  }
  .row-safe .col-6 .photo{
    width: 25%;
    float: left;
    padding-right: 3%;
  }
  .row-safe .col-6 .content{
    width: 72%;
    float: left;
  }
  .row-quality{
    margin-bottom: 25px;
  }
  .row-quality .col-photo{
    margin-bottom: 1em;
  }
  .title-quality{
    font-size: 20px;
  }
  .title-mama-big{
    font-size: 30px;
  }
  .with-obj-mama{
    background-size: 200px;
    background-position: center top;
    padding-top: 210px;
  }
  .row-graph-mama .col-graph-mama{
    margin-bottom: 1.5em;
  }
  .shisutemu{
	font-size: 18px;
	margin-left: 3px;
	}
  .miryoku{
	font-size: 20px;
	}
  .text-nest {
		font-size: 18px;
		font-weight: bold;
		color: crimson;
	    margin-top: 27px;
	}
  .text-ene {
	    color: crimson;
		font-size: 15px;
		font-weight: bold;
	    margin-top: 5px;
	    text-align: left;
	}
  .nest-icon img {
		max-width: 18%;
		margin-bottom: -20px;
		margin-top: 20px;
	}
	.nest-content {
		margin-bottom: -15px;
	}
	.nest-notes {
		text-align: left;
	}
}

/*ECOライグ冷暖房、太陽光発電調整 20240408*/
.solar-wrap_01 {
  margin-bottom: 3vw;
}
.solar-content {
  background-color: #fff;
  padding: 15px;
  border-radius: 15px;
}
.solar-content.content02, .solar-content.content03 {
  margin-bottom: 3vw;
}
.solar-content h3 {
  font-size: max(14px, 2.4vw);
  font-weight: bolder;
  margin-bottom: 15px;
}
.solar-content.content01 h3 {
  margin-bottom: 0;
}
.content-flex {
  display: flex;
  justify-content: space-between;
  gap: 2%;
  align-items: flex-start;
}
.content01 .content01-1 img.content-img_01 {
  width: 35%;
  max-width: 200px;
  height: auto;
}
.content01 .content01-1 img.content-img_02 {
  width: 55%;
  max-width: 300px;
  height: auto;
}
.content01 .content01-2 img.content-img_01 {
  width: 100%;
  height: auto;
  margin-top: 5px;
}
.content01 .content01-2 img.content-img_02 {
  width: 55%;
  height: auto;
}
.content02 img.content-img_01 {
  width: 85%;
  height: auto;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.content03 img.content-img_01 {
  width: 85%;
  height: auto;
  display: block;
  margin-bottom: 15px;
  margin-left: auto;
  margin-right: auto;
}
.content03 img.content-img_02 {
  width: 85%;
  height: auto;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.content04 img.content-img_01 {
  width: 18%;
  display: block;
  padding: 15px;
}
.content03 .content-flex {
  display: block;
}
.content04 .content-flex .content-right {
  width: 78%;
}
.solar-content p {
  margin-bottom: 10px;
}
.content-right p {
  margin-bottom: 10px;
}
.content-right p:last-child {
  margin-bottom: 0;
}
.content01 .content01-1 .content-flex {
  justify-content: space-around;
  padding: 15px;
}
.solar-top_text {
  margin-bottom: 10px;
}
.title-iezukuri {
  margin-bottom: 15px;
}
.shisutemu p {
  margin-bottom: 15px;
}
@media print,screen and (min-width: 741px) {
  .hide-pc {
    display: none;
  }
  .solar-area h3 {
    font-size: 24px;
  }
  .solar-area p {
    font-size: 20px;
  }
  .solar-wrap_01 {
    margin-bottom: 30px;
  }
  .solar-content {
    padding: 30px;
    border-radius: 30px;
  }
  .content01 {
    position: relative;
  }
  .content01 h3 {
    width: 70%;
    margin-left: auto;
  }
  .content01 .content-flex {
    padding: 0;
  }
  .content01 .content01-1 {
    width: 25%;
    height: fit-content;
    display: flex;
    position: absolute;
    margin-top: -40px;
  }
  .content01 .content01-1 img.content-img_01 {
    width: 97%;
    max-width: initial;
    margin-top: auto;
    margin-left: auto;
  }
  .content01 .content01-1 img.content-img_02 {
    display: none;
  }
  .content01 .content01-2 {
    width: 70%;
    margin-left: auto;
  }
  .content01 .content01-2 .content-flex {
    margin-top: -20px;
  }
  .content01 .content01-2 img.content-img_01 {
    width: 60%;
    height: fit-content;
    margin-top: auto;
  }
  .content01 .content01-2 img.content-img_02 {
    width: 37%;
    height: fit-content;
  }
  .solar-wrap_02 {
    display: flex;
    justify-content: space-between;
    gap: 30px;
  }
  .solar-content.content02 {
    width: 520px;
    margin-bottom: 0;
  }
  .solar-wrap_02-inner {
    width: 580px;
  }
  .solar-content.content03 {
    margin-bottom: 30px;
  }
  .content03 .content-flex {
    display: flex;
    justify-content: space-between;
  }
  .content03 img.content-img_01 {
    width: 53.5%;
    height: auto;
    display: block;
    margin: initial;
  }
  .content03 img.content-img_02 {
    width: 44%;
    height: auto;
    display: block;
  }
  .solar-content.content04 {
    margin-bottom: 0;
  }
  .shisutemu {
    margin-bottom:-1.0em;
    color: #029FFD;
    margin-left: 32px;
  }
  .shisutemu p {
    font-size: 25px;
    margin-bottom: 1.5em;
  }
  .solar-top_text {
    font-size: 25px;
    margin-bottom: 0.5em;
    margin-left: 32px;
  }
  .solar-area h3.title-iezukuri {
    font-size: 30px;
  }
}
@media only screen and (max-width: 740px) {
  .hide-sp {
    display: none;
  }
}



.zenkankucho-inner {
  padding: 0 30px;
}
.zenkankucho-img {
  max-width: 900px;
  margin: 1em auto 1em;
}
.zenkankucho-img img {
  border-radius: 30px;
  overflow: hidden;
}
.link-btn {
  font-family: "UD新ゴNT M", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
}
.zenkankucho-inner .link-btn a {
  text-decoration-line: none;
  color: #000;
  padding: 20px 75px;
  background-color: #ff0;
  position: relative;
}
.zenkankucho-inner .link-btn {
  margin-top: 2em;
}
.zenkankucho-inner .zenkankucho-caption p {
  width: fit-content;
  margin-left: auto;
  text-indent: -1em;
  padding-left: 1em;
}
@media only screen and (max-width: 740px) {
  .zenkankucho-inner {
    padding: 0;
  }
  .zenkankucho-inner img {
    padding-top: 0;
    margin-bottom: 0;
  }
  .zenkankucho-inner .link-btn a {
    padding: 12px 30px;
  }
}

/* 調整 - 20250415 */
.title-iezukuri {
  margin-bottom: 30px;
}
.title-iezukuri span {
  white-space: nowrap;
}
.solar-contents {
  display: flex;
  width: 100%;
  gap: 0 30px;
}
.solar-content {
  padding: 25px 30px 30px;
}
.solar-content h3 {
  border-bottom: 2px solid #DE6D36;
  margin-bottom: 1em;
}
.solar-content p {
  margin-bottom: 1em;
  font-size: 16px;
}
.solar-content.solar-left {
  max-width: 330px;
}
.solar-content.solar-left .solar-content-img {
  max-width: 405px;
  display: flex;
  justify-content: center;
  margin: auto;
}
.solar-content.solar-right {
  max-width: 710px;
}
.solar-content.solar-right .solar-content-img {
  max-width: 405px;
  display: flex;
  justify-content: center;
  margin: -30px auto 0;
}
@media only screen and (max-width: 740px) {
  .title-iezukuri {
    margin-bottom: 15px;
  }
  .solar-contents {
    display: block;
  }
  .solar-content {
    padding: 15px 20px 20px;
    margin-bottom: 15px;
  }
  .solar-content:last-of-type {
    margin-bottom: 0;
  }
  .solar-content h3 {
    font-size: 16px;
  }
  .solar-content p {
    font-size: 13px;
  }
  .solar-content.solar-left, .solar-content.solar-right {
    max-width: 100%;
  }
  .solar-content.solar-right .solar-content-img {
    margin-top: 0;
  }
}


.kodawari4-flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.kodawari4-flex figure {
  width: 250px;
}
.kodawari4-flex figure figcaption span {
  white-space: nowrap;
}
.caption-safe {
  width: 100%;
  height: 3.2em;
  box-sizing: border-box;
}
@media only screen and (max-width: 740px) {
  .kodawari4-flex figure {
    width: calc(100% / 2.5);
  }
  .caption-safe {
    height: 3.5em;
  }
}
