@charset "utf-8";
@import url("root.css");

/***************************************
------------- news -------------
***************************************/

.estate_top{background: url("../img/estate_top.jpg") top right no-repeat, var(--base-color05);}
.construction-work_top{background: url("../img/construction-work_top.jpg") top right no-repeat, var(--base-color05);}
.erenewable-energy_top{background: url("../img/erenewable-energy_top.jpg") top right no-repeat, var(--base-color05);}
.company_top{background: url("../img/company_top.jpg") top right no-repeat, var(--base-color05);}

@media screen and (max-width: 900px) {
.estate_top{margin: 56px auto 0;background: url("../img/estate_top_sp.jpg") top right no-repeat, var(--base-color05);background-size:contain;}
.construction-work_top{margin: 56px auto 0;background: url("../img/construction-work_top_sp.jpg") top right no-repeat, var(--base-color05);background-size:contain;}
.erenewable-energy_top{margin: 56px auto 0;background: url("../img/erenewable-energy_top_sp.jpg") top right no-repeat, var(--base-color05);background-size:contain;}
.company_top{margin: 56px auto 0;background: url("../img/company_top_sp.jpg") top right no-repeat, var(--base-color05);background-size:contain;}

}


#solutiones .txt_box{
margin:0 auto;
padding: 0 0 110px 0;
text-align: center;
}

.txt_box_d{
margin:0 auto;
padding:70px 0 110px 0;
text-align: left;
width: 1200px;

}

#solutiones .txt_box h3{
color: var(--base-color01);
font-size: 36px;
font-weight: 600;
font-family: 'Roboto', sans-serif;
line-height: 1.6;
}

#solutiones .txt_box p{
padding: 20px 0 0 0;
}

.ceo_name{
font-family: 'Sawarabi Mincho', serif;
font-size: 28px;
text-align: right;
padding: 20px 0 0 0;
font-weight: 600;
}

@media screen and (max-width: 900px) {

#solutiones .txt_box{
width: 90%;
padding: 0 0 40px 0;
}

#solutiones .txt_box_d{
width: 90%;
padding:40px 0;
}

#solutiones .txt_box h3{
}

#solutiones .txt_box p{
}

}

#solutiones .txt_box_a {
background: url("../img/bg_logo.png")top left no-repeat;
background-color: var(--base-color05);
margin: 0 auto;
text-align: center;
}
#solutiones .txt_box_a_p {
padding: 40px 0;
}

#solutiones .txt_box_a_bttom{
background: url("../img/bg_logo.png")bottom right no-repeat;
padding: 70px 0 95px 0;
}



#solutiones .row{
display: flex;
width: 1200px;
margin: 30px auto 0;
justify-content: flex-start;
}
#solutiones .col_03{
margin: 0 15px 15px 0;
width: 380px;
}

#solutiones .col_03:nth-child(3n){
margin: 0 0 15px 0;
}

#solutiones .col_03 p{
font-weight: 400;
padding: 0;
}

#solutiones .col_03 dl{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
background-color: var(--base-color03);
border:10px solid #E5F0EC;
padding:15px;
box-sizing: border-box;
}

#solutiones .col_03 dt{width: 30%;}
#solutiones .col_03 dd{
width: 70%;
padding: 0 0 0 15px;
font-weight: 600;
font-size: 20px;
}

#solutiones .col_03 img{
width: 90px;
height: 90px;
border-radius: 50%;
object-fit: cover;
overflow: hidden;
}

#solutiones .col_04 dl{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
background-color: var(--base-color03);
border:10px solid #E5F0EC;
padding:15px;
box-sizing: border-box;
}

#solutiones .col_04 dt{width: 100%;text-align: center;}
#solutiones .col_04 dd{
width: 100%;
padding:10px 0 0 0;
font-weight: 600;
font-size: 20px;
text-align: center;
}

#solutiones .col_04 img{
max-width:100%;
object-fit: cover;
overflow: hidden;
}


@media screen and (max-width: 900px) {
#solutiones .txt_box_a {background-size: 60%;}
#solutiones .txt_box_a_bttom{background-size: 60%;padding: 40px 0;}

#solutiones .txt_box_a_p {
padding: 20px 0;
margin: 0 auto;
width: 90%;
text-align: left;
}


#solutiones .row{
width:90%;
margin: 20px auto 0;
}
#solutiones .col_03{
width: 100%;
margin: 0 auto 10px;
}

#solutiones .col_03 dl{
border:5px solid #E5F0EC;
padding:10px;
}

#solutiones .col_03 dt{}
#solutiones .col_03 dd{font-size: 18px;}

#solutiones .col_03 img{
width: 90px;
height: 90px;
border-radius: 50%;
object-fit: cover;
overflow: hidden;
}

#solutiones .col_04{
width: 100%;
margin: 0 auto 10px;
}

#solutiones .col_04 dl{
border:5px solid #E5F0EC;
padding:10px;
}

#solutiones .col_04 dt{width: 40%;}
#solutiones .col_04 dd{font-size:16px;width:60%;text-align: left;padding: 0 0 0 20px;}

#solutiones .col_04 img{
width:100%;
border-radius:0;
object-fit: cover;
overflow: hidden;
}


}



#solutiones .img_box{
position: relative;
width: 100%;

display: flex;
margin: 70px auto 110px;
}

#solutiones .image-wrap {
position: absolute;
left: 0;
top: 0;
bottom: 0;
width: 35%;
overflow: hidden;
z-index: 1;

}

#solutiones .image-wrap img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}

#solutiones .image-wrap_box {
position: relative;
z-index: 2;
width: 1200px;
margin: 0 auto;
display: flex;
justify-content: flex-end;
align-items: center;
padding:0;
box-sizing: border-box;
}

#solutiones .image-wrap_txt {
width:60%;
padding: 70px 0;
}

#solutiones .image-wrap_txt_b {
width:60%;
padding: 40px 0 0 0;
}

#solutiones .image-wrap_txt_b p{
padding: 30px 0 0 0;text-align: left;
}


#solutiones .image-wrap_txt p{
padding: 30px 0 0 0;

}

#solutiones .image-wrap_txt ul {
border-top: 1px solid #CCCCCC;
list-style-type: disc;
list-style-position: inside;
margin: 20px auto 0;
}

#solutiones .image-wrap_txt li {
border-bottom: 1px solid #CCCCCC;
padding: 15px 20px;
}

@media screen and (max-width: 900px) {


#solutiones .image-wrap_txt ul {
margin: 20px auto 0;
}


#solutiones .img_box {
position: static !important;
width: 100%;
height:auto;
display: flex;
margin:0 auto 0;
flex-wrap: wrap;
}

#solutiones .image-wrap {
position: static !important;
left: 0;
top: 0;
bottom: 0;
width: 100%;
overflow: hidden;
z-index: 1;
}

#solutiones .image-wrap img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}

#solutiones .image-wrap_box {
position: relative;
z-index: 2;
width: 90%;
max-width:100%;
margin: 40px auto;
display: flex;
justify-content:space-between;
align-items: center;
padding:0;
box-sizing: border-box;
flex-wrap: wrap;
}

#solutiones .image-wrap_txt {
width:100%;
padding:0;
}

#solutiones .image-wrap_txt_b {
width:100%;
padding:0;
text-align: center;
margin: 0 auto 0;
}


#solutiones .image-wrap_txt span {
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
}
}

#solutiones .txt_box_b {
background: url("../img/bg_c.jpg")top left no-repeat;
background-size: cover;
margin: 0 auto;
text-align: center;
padding: 70px 0 110px 0;
}

#solutiones .txt_box_b_in {
width: 1200px;
margin: 0 auto;
text-align: left;
}

#solutiones .col{
width:49%;
margin: 0 2% 2% 0;
border:5px solid #E5F0EC;
background-color: rgba(255, 255, 255, 0.18);
padding:15px 25px;
box-sizing: border-box;
}

#solutiones .col:nth-child(2n){
width:48%;
margin: 0 0 2% 0;
}


@media screen and (max-width: 900px) {
#solutiones .txt_box_b {
background: url("../img/bg_c.jpg")top left no-repeat;
background-size: cover;
margin: 0 auto;
text-align: center;
padding: 40px 0;
}

#solutiones .txt_box_b_in {
width:90%;
margin: 0 auto;
text-align: left;
}

#solutiones .txt_box_b_in span {
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
}


#solutiones .txt_box_b_in .row{
width:100%;
}

#solutiones .col{
width:100%;
margin:0 auto 20px;
border:2px solid #E5F0EC;
background-color: rgba(255, 255, 255, 0.18);
padding:15px 25px;
}

#solutiones .col:nth-child(2n){
width:100%;
margin:0 auto 20px;
}

}


#solutiones .txt_box_b h4{
color: var(--base-color03);
font-size: 24px;
font-weight: 600;
}

#solutiones .txt_box_b p{
color: var(--base-color03);
}

#solutiones .txt_box_b h3{color: var(--base-color03);}
#solutiones .txt_box_b span{color: var(--base-color03);}

#solutiones .box .title_a{
text-align: left;
}

#solutiones .box .title_a p{
padding: 40px 0;
}

#solutiones .box dl{
background: url("../img/flow_bg.png")top center repeat-y;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items:center;
margin: 40px auto 0;
}

#solutiones .box dt{
background-color: #ffffff;
margin: 0 auto 40px;
width: 300px;
}

#solutiones .box dd{
width:900px;
background-color: #ffffff;
margin: 0 auto 40px;
border: 5px solid #E5F0EC;
position: relative;
padding: 30px 30px 30px 90px;
box-sizing: border-box;
text-align: left;
}

#solutiones .box dl dd:last-child{
margin: 0 auto 0;
}


#solutiones .box dd h4{
font-size: 24px;
font-weight: 600;
padding: 0 0 0 0;
}


#solutiones .box span{
font-family: 'Roboto', sans-serif;
}

#solutiones .box dd span {
display: inline-block;
width: 90px;
height: 90px;
background-color:var(--base-color01);
color:var(--base-color03);
border-radius: 50%;
font-family: 'Roboto', sans-serif;
font-size:36px;
font-weight: bold;
text-align: center;
line-height:2.6;
margin-right: 10px;
position: absolute;
top: 50%;
transform: translateY(-50%);
left:-50px;
  
}

@media screen and (max-width: 900px) {
#solutiones .box span {
text-align: center;
margin: 0 auto;
display: flex;
justify-content: center;
}


#solutiones .txt_box_b h4{
font-size:20px;
}

#solutiones .txt_box_b p{}

#solutiones .txt_box_b h3{}
#solutiones .txt_box_b span{}
#solutiones .box .title_a{}

#solutiones .box dl{
background: url(".")top center repeat-y;
margin: 20px auto 0;
justify-content: flex-start;
}

#solutiones .box dt{
background-color: #ffffff;
margin:0 auto 20px;
width:23%;
padding: 0 15px 0 0;
}

#solutiones .box dd{
width:77%;
margin: 0 auto 20px;
border: 0;
padding:0;
box-sizing: border-box;
text-align: left;
gap: 10px;
display: flex !important;
align-items: center !important;
justify-content: flex-start !important; /* ← 左寄せに変更 */
flex-wrap: wrap;
}

#solutiones .box dd p{
font-size: 14px;
padding: 10px 0 0 0;
border-top: 2px solid var(--base-color01);
}
#solutiones .box dl dd:last-child{
margin: 0 auto 0;
}


#solutiones .box dd h4{
font-size:20px;
font-weight: 600;
padding: 0 0 0 0;
}



  #solutiones .box dd span {
display: inline-flex !important;
justify-content: center;
align-items: center;
width: 40px;
height: 40px;
padding:0;
background-color: var(--base-color01);
color: var(--base-color03);
border-radius: 50%;
font-family: 'Roboto', sans-serif;
font-size: 24px;
font-weight: bold;
text-align: center;
line-height: 1;
margin-right:5px;
position: static !important;
transform: none !important;
top: auto !important;
left: auto !important;
}

#solutiones .box dd h4 {
font-size: 20px;
font-weight: 600;
width: calc(100% - 60px);
}
}

#solutiones .txt_box_c{
padding: 70px 0 95px 0;
background-color: #E7F2EE;
margin: 0 auto 40px;
}

#solutiones .txt_box_c .title_a{
margin: 0 auto 0;
width: 1000px;
text-align: center;
}

#solutiones .row_g {
display: flex;
flex-wrap: wrap;
width: 1000px;
margin: 40px auto 0;
justify-content: flex-start;
}


#solutiones .col_in{
width: calc(25% - 1.5%); 
margin: 0 2% 20px 0;
}
#solutiones .col_in:nth-child(4n) {
margin-right: 0;
}


#solutiones .col_in h4{
font-size:16px;
font-weight: 600;
padding: 0 0 10px 0;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis; 
}

#solutiones .col_in img{
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}



@media screen and (max-width: 900px) {
#solutiones .txt_box_c{
padding: 40px 0;
}

#solutiones .txt_box_c .title_a{
margin: 0 auto 0;
width: 90%;
}

#solutiones .row_g {
display: flex;
flex-wrap: wrap;
width: 90%;
margin: 20px auto 0;
justify-content: flex-start;
}


#solutiones .col_in{
width: 100%;
margin: 0 0 2% 0;
box-sizing: border-box;
}

#solutiones .col_in h4{
font-size: 16px;
font-weight: 600;
padding: 0 0 10px 0;
}

#solutiones .col_in:nth-child(2n) {
width: 100%;
margin: 0 0 2% 0;
}

#solutiones .col_in dl{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

#solutiones .col_in dd{
width: 48%;
margin: 0 4% 0 0;
}

#solutiones .col_in dd:nth-child(2n){
margin: 0 0 0 0;
}


}


#solutiones .image-wrap_txt dl{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 40px auto 0;
}

#solutiones .image-wrap_txt dt{
width: 30%;
background-color:var(--base-color01);
color:var(--base-color03);
border-bottom: 1px solid var(--base-color03);
padding: 15px;
text-align: center;
}

#solutiones .image-wrap_txt dd{
width: 70%;
background-color:var(--base-color05);
border-bottom: 1px solid var(--base-color03);
padding: 15px;
}
#solutiones .image-box{
margin:40px auto 0;
}
@media screen and (max-width: 900px) {
#solutiones .image-wrap_txt dl{
margin: 20px auto 0;
}

#solutiones .image-wrap_txt dt{
width: 100%;
}

#solutiones .image-wrap_txt dd{
width: 100%;
}
#solutiones .image-box{
margin:20px auto 0;
}
}

#privacy-policy h3{
margin:40px auto;
padding: 0 0 10px 0;
color: var(--base-color01);
font-size:24px;
font-weight: 600;
border-bottom: 3px solid var(--base-color01);
}
#privacy-policy .txt_box {
margin: 0 auto;
width: 90%;
padding:0 0;
}


#works h3{
font-size: 24px;
font-weight: 600;
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
border-bottom: 3px solid var(--base-color01);
padding: 0 0 15px 0;
}

#works h3 span{
width: 110px;
text-align: center;
padding: 0 0;
box-sizing: border-box;
margin: 0 20px 0 0;
background-color: var(--base-color01);
color: var(--base-color03);
display: flex;
align-items: center;
justify-content: center;
font-size: 14px;
}

#works img{
margin: 0 auto 40px;
max-width: 100%;
}

@media screen and (max-width: 900px) {

#works h3{
font-size:18px;
font-weight: 600;
display: flex;
flex-wrap: wrap;
justify-content: flex-start;
border-bottom: 3px solid var(--base-color01);
padding: 0 0 5px 0;
margin: 0 auto;
width: 90%;
}

#works h3 span{
width: 110px;
text-align: center;
padding: 0 0;
box-sizing: border-box;
margin: 0 20px 0 0;
background-color: var(--base-color01);
color: var(--base-color03);
display: flex;
align-items: center;
justify-content: center;
font-size: 14px;
}

#works img{
margin: 0 auto 20px;
max-width: 100%;
}

#works .txt_box {
margin: 0 auto;
width: 90%;
padding: 40px 0 40px 0;
    }

}