/* ========================================================================================= ^^
  Key visual for ZEH
============================================================================================ ^^ */
.c-key-visual {
  background: url(../images/zeh/kv.jpg) no-repeat 50% 100%/cover;
}

/* ========================================================================================= ^^
  ZEH upper
============================================================================================ ^^ */
#container .p-zeh-upper {
  width: 100vw;
  padding: calc(50 * var(--min-ratio)) calc(10 * var(--min-ratio));
  margin: 0 calc(50% - 50vw);
  background: linear-gradient(90deg, rgb(217, 215, 204) 0%, rgb(222, 220, 211) 2.93%, rgb(231, 229, 222) 10.96%, rgb(236, 234, 229) 22.25%, rgb(237, 235, 231) 53.62%, rgb(236, 233, 229) 80.01%, rgb(231, 228, 222) 89.52%, rgb(224, 219, 211) 96.27%, rgb(217, 210, 200) 100%);
}
@media (min-width: 768px) {
  #container .p-zeh-upper {
    padding: calc(100 * var(--max-ratio)) calc(10 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-upper {
    padding: calc(100 * var(--rem-ratio)) calc(10 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  About ZEH
============================================================================================ ^^ */
#container .p-about-zeh {
  padding-top: calc(44 * var(--min-ratio));
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-about-zeh {
    padding-top: calc(87 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh {
    padding-top: calc(87 * var(--rem-ratio));
  }
}
#container .p-about-zeh h2.c-title {
  margin-bottom: calc(31 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#container .p-about-zeh h2.c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
@media (min-width: 768px) {
  #container .p-about-zeh h2.c-title {
    margin-bottom: calc(31 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh h2.c-title {
    margin-bottom: calc(31 * var(--rem-ratio));
  }
}
#container .p-about-zeh .c-text {
  margin-bottom: calc(40 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}
@media (min-width: 768px) {
  #container .p-about-zeh .c-text {
    margin-bottom: calc(80 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh .c-text {
    margin-bottom: calc(80 * var(--rem-ratio));
  }
}
#container .p-about-zeh .c-box {
  max-width: 1120px;
  width: 100%;
  /* padding: calc(47 * var(--min-ratio)) calc(10 * var(--min-ratio)); */
  padding: calc(48 * var(--min-ratio)) calc(40 * var(--min-ratio));
  margin: 0 auto;
  background-color: #ecf5e9;
  grid-template-columns: 100%;
  align-items: start;
  row-gap: calc(30 * var(--min-ratio));
  filter: drop-shadow(0 3px 15px rgba(133, 124, 118, 0.48));
}
@media (min-width: 768px) {
  #container .p-about-zeh .c-box {
    padding: calc(67 * var(--max-ratio)) calc(98 * var(--max-ratio)) calc(67 * var(--max-ratio)) calc(60 * var(--max-ratio));
    /* grid-template-columns: 44.4015444015% 1fr;
    -moz-column-gap: 4.8262548263%;
    column-gap: 4.8262548263%; */
    grid-template-columns: calc((534 / 964) * 100%) calc((365 / 964) * 100%);
    column-gap: calc((65 / 964) * 100%);
    row-gap: unset;
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh .c-box {
    padding: calc(67 * var(--rem-ratio)) calc(98 * var(--rem-ratio)) calc(67 * var(--rem-ratio)) calc(60 * var(--rem-ratio));
  }
}

#container .p-about-zeh .c-box .c-image h4 {
  margin-bottom: calc(10 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.774rem + 0.43vw, 1.125rem);
  font-weight: 500;
}
#container .p-about-zeh .c-box .c-image figcaption {
  padding-top: calc(8 * var(--min-ratio));
  font-size: clamp(0.625rem, 0.625rem + 0vw, 0.625rem);
  line-height: 1.8;
  text-align: left;
}
@media (min-width: 768px) {
  #container .p-about-zeh .c-box .c-image {
    grid-column: 2/3;
    grid-row: 1/2;
  }
  #container .p-about-zeh .c-box .c-image h4 {
    margin-bottom: calc(10 * var(--max-ratio));
    font-size: clamp(0.875rem, 0.514rem + 0.75vw, 1.125rem);
  }
  #container .p-about-zeh .c-box .c-image figcaption {
    padding-top: calc(8 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh .c-box .c-image h4 {
    margin-bottom: calc(10 * var(--rem-ratio));
  }
  #container .p-about-zeh .c-box .c-image figcaption {
    padding-top: calc(8 * var(--rem-ratio));
  }
}

#container .p-about-zeh .c-box .c-content {
  color: #333;
}
@media (min-width: 768px) {
  #container .p-about-zeh .c-box .c-content {
    grid-column: 1/2;
    grid-row: 1/2;
  }
}
#container .p-about-zeh .c-box .c-content h3.c-title {
  margin: 0 calc(-10 * var(--min-ratio)) calc(16 * var(--min-ratio));
  font-family: var(--font-shippori);
  /* font-size: clamp(0.938rem, 0.76rem + 0.76vw, 1.375rem); */
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.5454545455;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: left;
}
@media (min-width: 768px) {
  #container .p-about-zeh .c-box .c-content h3.c-title {
    margin: 0 0 calc(46 * var(--max-ratio));
    font-size: clamp(0.938rem, 0.76rem + 0.76vw, 1.375rem);
  }
}
@media (min-width: 1300px) {
  #container .p-about-zeh .c-box .c-content h3.c-title {
    margin-bottom: calc(46 * var(--rem-ratio));
  }
}
#container .p-about-zeh .c-box .c-content .c-text {
  margin-bottom: 0;
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
  line-height: 2.4285714286;
  letter-spacing: 0.08em;
  text-align: left;
}

/* ========================================================================================= ^^
  Eco
============================================================================================ ^^ */
#container .p-eco {
  /* padding: calc(48 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(30 * var(--min-ratio)); */
  padding: calc(48 * var(--min-ratio)) calc(40 * var(--min-ratio)) calc(30 * var(--min-ratio));
  background-color: #fff;
}
@media (min-width: 768px) {
  #container .p-eco {
    padding: calc(95 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(30 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-eco {
    padding: calc(95 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(30 * var(--rem-ratio));
  }
}
#container .p-eco .l-section__inner {
  grid-template-columns: 100%;
}
@media (min-width: 768px) {
  #container .p-eco .l-section__inner {
    grid-template-columns: 42.8571428571% 1fr;
    -moz-column-gap: 6.4285714286%;
    column-gap: 6.4285714286%;
  }
}
#container .p-eco .c-title {
  margin: 0 calc(-15 * var(--min-ratio)) calc(18 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-eco .c-title {
    margin: 0 0 calc(16 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-eco .c-title {
    margin-bottom: calc(16 * var(--rem-ratio));
  }
}
#container .p-eco h3 {
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  font-weight: 400;
}
#container .p-eco .c-text {
  margin-bottom: calc(40 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}

@media (min-width: 768px) {
  #container .p-eco .c-text {
    margin-bottom: calc(40 * var(--max-ratio));
  }
  #container .p-eco h3 + .c-text {
    margin-bottom: 0;
  }
}
@media (min-width: 1300px) {
  #container .p-eco .c-text {
    margin-bottom: calc(40 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-eco .c-content {
    grid-column: 2/3;
    grid-row: 1/2;
  }
}
@media (min-width: 768px) {
  #container .p-eco .c-image {
    grid-column: 1/2;
    grid-row: 1/2;
  }
}

/* ========================================================================================= ^^
  ZEH M
============================================================================================ ^^ */
#container .p-zeh-m {
  padding: calc(13 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(50 * var(--min-ratio));
  background-color: #fff;
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-zeh-m {
    padding: calc(13 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(103 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-m {
    padding: calc(13 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(103 * var(--rem-ratio));
  }
}
#container .p-zeh-m .c-title {
  margin-bottom: calc(31 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
#container .p-zeh-m .c-title span {
  font-size: clamp(0.75rem, 0.623rem + 0.54vw, 1.063rem);
  line-height: 2.9411764706;
}
@media (min-width: 768px) {
  #container .p-zeh-m .c-title {
    margin-bottom: calc(31 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-m .c-title {
    margin-bottom: calc(31 * var(--rem-ratio));
  }
}
#container .p-zeh-m .c-text {
  margin-bottom: 0;
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
}

/* ========================================================================================= ^^
  Insulation
============================================================================================ ^^ */
#container .p-insulation {
  padding: calc(53 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(63 * var(--min-ratio));
  background: linear-gradient(90deg, rgb(217, 215, 204) 0%, rgb(222, 220, 211) 2.93%, rgb(231, 229, 222) 10.96%, rgb(236, 234, 229) 22.25%, rgb(237, 235, 231) 53.62%, rgb(236, 233, 229) 80.01%, rgb(231, 228, 222) 89.52%, rgb(224, 219, 211) 96.27%, rgb(217, 210, 200) 100%);
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-insulation {
    padding: calc(53 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(63 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation {
    padding: calc(53 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(63 * var(--rem-ratio));
  }
}
#container .p-insulation .c-title {
  margin-bottom: calc(43 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-insulation .c-title {
    margin-bottom: calc(85 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-title {
    margin-bottom: calc(85 * var(--rem-ratio));
  }
}
#container .p-insulation .c-grid {
  max-width: 1120px;
  width: 100%;
  margin: 0 auto;
  grid-template-columns: 100%;
  row-gap: calc(30 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: 2.6785714286%;
    column-gap: 2.6785714286%;
    row-gap: unset;
  }
}
#container .p-insulation .c-grid .c-box {
  width: 100%;
  height: 100%;
  padding: calc(48 * var(--min-ratio)) calc(40 * var(--min-ratio)) calc(20 * var(--min-ratio));
  background-color: #fff;
  color: #333;
  display: flex;
  flex-direction: column;
  filter: drop-shadow(0 3px 15px rgba(133, 124, 118, 0.48));
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box {
    padding: calc(48 * var(--max-ratio)) calc(40 * var(--max-ratio)) calc(20 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box {
    padding: calc(48 * var(--rem-ratio)) calc(40 * var(--rem-ratio)) calc(20 * var(--rem-ratio));
  }
}
#container .p-insulation .c-grid .c-box h3 {
  margin-bottom: calc(15 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(0.813rem, 0.686rem + 0.54vw, 1.125rem);
  line-height: 1.8888888889;
  font-weight: 700;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box h3 {
    margin-bottom: calc(49 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box h3 {
    margin-bottom: calc(49 * var(--rem-ratio));
  }
}
#container .p-insulation .c-grid .c-box .c-grid {
  grid-template-columns: 1fr 28.9855072464%;
}
#container .p-insulation .c-grid .c-box .c-grid .c-image {
  width: 100%;
  margin: 0;
}
#container .p-insulation .c-grid .c-box .c-text {
  margin-bottom: calc(30 * var(--min-ratio));
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
  line-height: 1.7142857143;
  letter-spacing: 0.08em;
  text-align: left;
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box .c-text {
    margin-bottom: calc(63 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box .c-text {
    margin-bottom: calc(63 * var(--rem-ratio));
  }
}
#container .p-insulation .c-grid .c-box .c-image {
  margin: auto auto 0;
}
#container .p-insulation .c-grid .c-box .c-image p {
  margin: calc(24 * var(--min-ratio)) 0 0;
  font-size: clamp(0.625rem, 0.625rem + 0vw, 0.625rem);
  line-height: 1.6;
  letter-spacing: 0.08em;
  text-align: left;
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box .c-image p {
    margin-top: calc(24 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box .c-image p {
    margin-top: calc(24 * var(--rem-ratio));
  }
}
#container .p-insulation .c-grid .c-box:nth-of-type(1) .c-image {
  width: calc(200 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box:nth-of-type(1) .c-image {
    width: calc(246 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box:nth-of-type(1) .c-image {
    width: calc(246 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-insulation .c-grid .c-box:nth-of-type(2) > .c-image {
    width: calc(470 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-insulation .c-grid .c-box:nth-of-type(2) > .c-image {
    width: calc(470 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Related equipment
============================================================================================ ^^ */
#container .p-related-equipment {
  padding: calc(50 * var(--min-ratio)) calc(10 * var(--min-ratio)) 0;
}
@media (min-width: 768px) {
  #container .p-related-equipment {
    padding: calc(100 * var(--max-ratio)) calc(10 * var(--max-ratio)) 0;
  }
}
@media (min-width: 1300px) {
  #container .p-related-equipment {
    padding: calc(100 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) 0;
  }
}
#container .p-related-equipment .l-section__inner {
  max-width: 1194px;
  width: 100%;
  padding: calc(33 * var(--min-ratio)) calc(18 * var(--min-ratio)) calc(32 * var(--min-ratio));
  margin: 0 auto;
  background-color: rgba(255, 255, 255, 0.65);
  color: #333;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-related-equipment .l-section__inner {
    padding: calc(66 * var(--max-ratio)) calc(37 * var(--max-ratio)) calc(64 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-related-equipment .l-section__inner {
    padding: calc(66 * var(--rem-ratio)) calc(37 * var(--rem-ratio)) calc(64 * var(--rem-ratio));
  }
}
#container .p-related-equipment .l-section__inner .c-title {
  margin-bottom: calc(24 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-related-equipment .l-section__inner .c-title {
    margin-bottom: calc(48 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-related-equipment .l-section__inner .c-title {
    margin-bottom: calc(48 * var(--rem-ratio));
  }
}
#container .p-related-equipment .l-section__inner .c-text {
  margin-bottom: calc(30 * var(--min-ratio));
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-related-equipment .l-section__inner .c-text {
    margin-bottom: calc(57 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-related-equipment .l-section__inner .c-text {
    margin-bottom: calc(57 * var(--rem-ratio));
  }
}
#container .p-related-equipment .l-section__inner .c-grid {
  grid-template-columns: 100%;
  row-gap: calc(30 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-related-equipment .l-section__inner .c-grid {
    grid-template-columns: repeat(3, 1fr);
    -moz-column-gap: 4.7169811321%;
    column-gap: 4.7169811321%;
    row-gap: calc(50 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-related-equipment .l-section__inner .c-grid {
    row-gap: calc(50 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  ZEH developer
============================================================================================ ^^ */
#container .p-zeh-developer {
  padding-bottom: calc(46 * var(--min-ratio));
  margin-top: calc(46 * var(--min-ratio));
  color: #333;
}
@media (min-width: 768px) {
  #container .p-zeh-developer {
    padding-bottom: calc(92 * var(--max-ratio));
    margin-top: calc(92 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer {
    padding-bottom: calc(92 * var(--rem-ratio));
    margin-top: calc(92 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .l-section__inner {
  padding: 0 calc(10 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-zeh-developer .l-section__inner {
    padding: 0 calc(38 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .l-section__inner {
    padding: 0 calc(38 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-content {
  width: 100vw;
  padding: calc(58 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(53 * var(--min-ratio));
  margin: 0 calc(50% - 50vw);
  background-color: #fff;
  filter: drop-shadow(0 3px 15px rgba(133, 124, 118, 0.48));
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-content {
    padding: calc(58 * var(--max-ratio)) calc(10 * var(--max-ratio)) calc(53 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-content {
    padding: calc(58 * var(--rem-ratio)) calc(10 * var(--rem-ratio)) calc(53 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-title {
  max-width: 1120px;
  margin: 0 auto calc(36 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(1.25rem, 1.047rem + 0.86vw, 1.75rem);
  line-height: 1.7857142857;
  font-weight: 500;
  letter-spacing: 0.08em;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-title {
    margin-bottom: calc(36 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-title {
    margin-bottom: calc(36 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-grid {
  max-width: 1120px;
  margin: 0 auto;
  grid-template-columns: 100%;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-grid {
    grid-template-columns: 1fr 28.515625%;
  }
}
#container .p-zeh-developer .c-text {
  font-size: clamp(0.875rem, 0.824rem + 0.22vw, 1rem);
  line-height: 2.5;
  letter-spacing: 0.08em;
}
#container .p-zeh-developer .c-image {
  width: calc(200 * var(--min-ratio));
  margin: calc(40 * var(--min-ratio)) auto 0;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-image {
    width: calc(200 * var(--max-ratio));
    margin: 0;
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-image {
    width: calc(200 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-carbon-neutral {
  width: 100vw;
  padding: calc(80 * var(--min-ratio)) 0 calc(80 * var(--min-ratio));
  margin: 0 calc(50% - 50vw) calc(64 * var(--min-ratio));
  background-color: #f6f1ea;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-carbon-neutral {
    padding: calc(80 * var(--max-ratio)) 0 calc(80 * var(--max-ratio));
    margin-bottom: calc(64 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-carbon-neutral {
    padding: calc(80 * var(--rem-ratio)) 0 calc(80 * var(--rem-ratio));
    margin-bottom: calc(64 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-carbon-neutral__inner {
  max-width: 640px;
  width: 100%;
  margin: 0 auto;
  aspect-ratio: 640/360;
}
#container .p-zeh-developer .c-carbon-neutral__inner iframe {
  width: 100% !important;
  height: 100% !important;
  display: block;
}
#container .p-zeh-developer .c-carbon-neutral h3 {
  margin-bottom: calc(23 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(0.875rem, 0.723rem + 0.65vw, 1.25rem);
  color: #333;
  line-height: 2.5;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-carbon-neutral h3 {
    margin-bottom: calc(23 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-carbon-neutral h3 {
    margin-bottom: calc(23 * var(--rem-ratio));
  }
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-carbon-neutral + .c-grid {
    grid-template-columns: repeat(2, 1fr);
    -moz-column-gap: 6.6964285714%;
    column-gap: 6.6964285714%;
  }
}
#container .p-zeh-developer .c-carbon-neutral + .c-grid .c-image {
  width: 100%;
  margin-top: calc(28 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-carbon-neutral + .c-grid .c-image {
    margin-top: calc(28 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-carbon-neutral + .c-grid .c-image {
    margin-top: calc(28 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-box h3 {
  margin-bottom: calc(18 * var(--min-ratio));
  padding-left: calc(20 * var(--min-ratio));
  border-left: 4px solid #685e59;
  font-family: var(--font-shippori);
  font-size: clamp(0.938rem, 0.76rem + 0.76vw, 1.375rem);
  color: #685e59;
  line-height: 1.2272727273;
  font-weight: 500;
  letter-spacing: 0.06em;
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-box h3 {
    padding-left: calc(20 * var(--max-ratio));
    margin-bottom: calc(18 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-box h3 {
    padding-left: calc(20 * var(--rem-ratio));
    margin-bottom: calc(18 * var(--rem-ratio));
  }
}
#container .p-zeh-developer .c-box .c-text {
  margin-bottom: 0;
  font-size: clamp(0.75rem, 0.699rem + 0.22vw, 0.875rem);
  line-height: 1.7142857143;
  letter-spacing: 0.08em;
  text-align: left;
}
#container .p-zeh-developer .c-box .c-text ul {
  display: grid;
  row-gap: calc(14 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-zeh-developer .c-box .c-text ul {
    row-gap: calc(27 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-zeh-developer .c-box .c-text ul {
    row-gap: calc(27 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  Endless green program
============================================================================================ ^^ */
#container .p-endless-green-program {
  padding: calc(20 * var(--min-ratio)) calc(10 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-endless-green-program {
    padding: calc(40 * var(--max-ratio)) calc(10 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-endless-green-program {
    padding: calc(40 * var(--rem-ratio)) calc(10 * var(--rem-ratio));
  }
}
#container .p-endless-green-program + .p-endless-green-program {
  padding-bottom: calc(25 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container .p-endless-green-program + .p-endless-green-program {
    padding-bottom: calc(50 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-endless-green-program + .p-endless-green-program {
    padding-bottom: calc(50 * var(--rem-ratio));
  }
}
#container .p-endless-green-program .l-section__inner {
  max-width: 1194px;
  width: 100%;
  padding: calc(20 * var(--min-ratio)) calc(10 * var(--min-ratio)) calc(16 * var(--min-ratio));
  margin: 0 auto;
  background-color: #fff;
  filter: drop-shadow(0 3px 15px rgba(133, 124, 118, 0.48));
}
@media (min-width: 768px) {
  #container .p-endless-green-program .l-section__inner {
    padding: calc(42 * var(--max-ratio)) calc(45 * var(--max-ratio)) calc(32 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-endless-green-program .l-section__inner {
    padding: calc(42 * var(--rem-ratio)) calc(45 * var(--rem-ratio)) calc(32 * var(--rem-ratio));
  }
}
#container .p-endless-green-program .c-title {
  margin-bottom: calc(11 * var(--min-ratio));
  font-family: var(--font-shippori);
  font-size: clamp(0.875rem, 0.723rem + 0.65vw, 1.25rem);
  line-height: 2.5;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-align: center;
}
@media (min-width: 768px) {
  #container .p-endless-green-program .c-title {
    margin-bottom: calc(11 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container .p-endless-green-program .c-title {
    margin-bottom: calc(11 * var(--rem-ratio));
  }
}

/* ========================================================================================= ^^
  ZEH
============================================================================================ ^^ */
#container #daiwa {
  padding-top: calc(50 * var(--min-ratio));
}
@media (min-width: 768px) {
  #container #daiwa {
    padding-top: calc(100 * var(--max-ratio));
  }
}
@media (min-width: 1300px) {
  #container #daiwa {
    padding-top: calc(100 * var(--rem-ratio));
  }
}