/*! ========================================================================
===========================================================================

	charm.css
	---------------------------
	// Last modified: 2025/11/10

===========================================================================
======================================================================== */
.contentsHeader {
  padding: 0;
  position: relative;
  line-height: 0;
}
.contentsHeader img {
  width: 100%;
}
.contentsHeader h1 {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  margin-right: -50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 2vw;
}
@media(max-width: 767px) {
  .contentsHeader h1 {
    font-size: 3vw;
  }
}
.area {
  width: 100%;
  padding: 80px 0 50px;
  background: #f9f5ee;
}
.area h2 {
  margin: 0 auto 70px;
  text-align: center;
  font-size: 2vw;
  font-weight: 700;
}
.area h3 {
  margin: 0 auto 30px;
  text-align: center;
  font-size: 1.5vw;
  font-weight: 700;
  letter-spacing: 0.2em;
}
.area h3 + p {
  margin: 0 auto 30px;
  text-align: center;
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 0.1em;
}
.area ul.area-p {
  max-width: 1000px;
  margin: 0 auto 50px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.area ul.area-p li:nth-child(1) {
  width: 73%;
}
.area ul.area-p li:nth-child(2) {
  width: 25.7%;
}
.area ul.area-p li p {
  text-align: right;
  font-size: 0.9vw;
}
.area ul.area-p li p small {
  margin: 10px 0 0;
  display: block;
}
.area figure {
  max-width: 680px;
  margin: 0 auto 50px;
}
.area figure figcaption {
  text-align: right;
  font-size: 0.9vw;
}
.area figure figcaption small {
  margin: 10px 0 0;
  display: block;
}
.area ul.data1, .area ul.data2 {
  max-width: 860px;
  margin: 0 auto 50px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-end;
}
.area ul.data2.tl {
  flex-direction: row-reverse;
}
.area ul.data1 li:nth-child(1), .area ul.data2 li:nth-child(1) {
  width: 40%;
}
.area ul.data1 li:nth-child(2), .area ul.data2 li:nth-child(2) {
  width: 55%;
}
.area ul.data1 li:nth-child(1) table, .area ul.data2 li:nth-child(1) table {
  width: 100%;
}
.area ul.data1 li:nth-child(1) table caption, .area ul.data2 li:nth-child(1) table caption {
  text-align: center;
  font-size: 0.8vw;
}
.area ul.data1 li:nth-child(1) table th, .area ul.data2 li:nth-child(1) table th {
  width: 50%;
  padding: 5px 0;
  text-align: center;
  background: #e3cd9b;
  border-bottom: 1px solid #333;
  font-size: 0.8vw;
}
.area ul.data2.td li:nth-child(1) table th {
  width: 40%;
}
.area ul.data2.td li:nth-child(1) table th:nth-child(1) {
  width: 25%;
}
.area ul.data1 li:nth-child(1) table td, .area ul.data2 li:nth-child(1) table td {
  width: 50%;
  padding: 5px 0;
  text-align: center;
  background: #fff;
  border-bottom: 1px solid #333;
  font-size: 0.8vw;
}
.area ul.data2.td li:nth-child(1) table td {
  width: 40%;
}
.area ul.data2.td li:nth-child(1) table td:nth-child(1) {
  width: 25%;
}
.area ul.data1 li:nth-child(1) table th:nth-child(odd), .area ul.data1 li:nth-child(1) table td:nth-child(odd), .area ul.data2 li:nth-child(1) table th:nth-child(odd), .area ul.data2 li:nth-child(1) table td:nth-child(odd), .area ul.data2.td li:nth-child(1) table th:nth-child(2), .area ul.data2.td li:nth-child(1) table td:nth-child(2) {
  border-right: 1px solid #333;
}
.area ul.data2.td li:nth-child(1) table th:nth-child(3), .area ul.data2.td li:nth-child(1) table td:nth-child(3) {
  border-right: 0 none;
}
.area ul.data1 li:nth-child(1) table tr.st td, .area ul.data2 li:nth-child(1) table tr.st td {
  background: #e6e6e6;
  color: #781723;
}
.area ul.data1 li:nth-child(1) table + p, .area ul.data2 li:nth-child(1) table + p {
  text-align: right;
  font-size: 0.7vw;
}
.area ul.data1 li:nth-child(2) div {
  width: 100%;
  margin: auto auto 0;
  padding: 15px 20px;
  background: #e6e6e6;
}
.area ul.data1 li:nth-child(2) div h4 {
  margin: 0 auto 10px;
  padding: 0 0 5px;
  border-bottom: 1px solid #333;
  font-size: 1vw;
  font-weight: 700;
}
.area ul.data1 li:nth-child(2) div p {
  font-size: 0.7vw;
  line-height: 1.6;
}
.area ul.data1 li:nth-child(2) div + p {
  width: 100%;
  text-align: right;
  font-size: 0.7vw;
}
.area ul.data2 li:nth-child(2) {
  margin: 20px 0 auto;
}
.area ul.data2 li:nth-child(2) h4 {
  margin: 0 auto 10px;
  font-size: 1.2vw;
  line-height: 1.6;
  font-weight: 700;
}
.area ul.data2 li:nth-child(2) h5 {
  margin: 20px auto 10px;
  font-size: 1vw;
  line-height: 1.6;
  font-weight: 700;
}
.area ul.data2 li:nth-child(2) p {
  line-height: 1.6;
}
.area ul.data2.tl li:nth-child(1) p {
  text-align: right;
  font-size: 0.7vw;
}
.area .data3 {
  max-width: 850px;
  margin: 50px auto 0;
}
.area .data3 h4 {
  margin: 0 auto 10px;
  font-size: 1.2vw;
  line-height: 1.6;
  font-weight: 700;
}
.area .data3 h5 {
  margin: 20px auto 10px;
  font-size: 1vw;
  line-height: 1.6;
  font-weight: 700;
}
.area .data3 p {
  font-size: 0.8vw;
  line-height: 1.6;
}
ul.hazardmap {
  max-width: 850px;
  margin: 50px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
ul.hazardmap li:nth-child(1) {
  width: 46.5%;
}
ul.hazardmap li:nth-child(2) {
  width: 50%;
}
@media(max-width: 767px) {
  .area {
    padding: 30px 20px 20px;
  }
  .area h2 {
    margin: 0 auto 20px;
    font-size: 5vw;
  }
  .area h3 {
    margin: 0 auto 20px;
    font-size: 3.5vw;
  }
  .area h3 + p {
    margin: 0 auto 30px;
    text-align: left;
    font-size: 3vw;
  }
  .area ul.area-p li p {
    font-size: 2vw;
  }
  .area figure {
    margin: 0 auto 30px;
  }
  .area figure figcaption {
    font-size: 2vw;
  }
  .area ul.data1, .area ul.data2 {
    margin: 0 auto 30px;
  }
  .area ul.data1 li:nth-child(1), .area ul.data2 li:nth-child(1) {
    width: 100%;
    margin: 0 auto 10px;
  }
  .area ul.data1 li:nth-child(2), .area ul.data2 li:nth-child(2) {
    width: 100%;
  }
  .area ul.data1 li:nth-child(1) table caption, .area ul.data2 li:nth-child(1) table caption {
    font-size: 3vw;
  }
  .area ul.data1 li:nth-child(1) table th, .area ul.data2 li:nth-child(1) table th {
    font-size: 3vw;
  }
  .area ul.data1 li:nth-child(1) table td, .area ul.data2 li:nth-child(1) table td {
    font-size: 3vw;
  }
  .area ul.data1 li:nth-child(1) table + p, .area ul.data2 li:nth-child(1) table + p {
    font-size: 3vw;
  }
  .area ul.data1 li:nth-child(2) div h4 {
    font-size: 4vw;
  }
  .area ul.data1 li:nth-child(2) div p {
    font-size: 3vw;
  }
  .area ul.data1 li:nth-child(2) div + p {
    font-size: 3vw;
  }
  .area ul.data2 li:nth-child(2) h4 {
    font-size: 4vw;
  }
  .area ul.data2 li:nth-child(2) h5 {
    font-size: 3.5vw;
  }
  .area ul.data2 li:nth-child(2) p {
    font-size: 3vw;
  }
  .area ul.data2.tl li:nth-child(1) p {
    font-size: 3vw;
  }
  .area .data3 {
    margin: 30px auto 0;
  }
  .area .data3 h4 {
    font-size: 4vw;
  }
  .area .data3 h5 {
    font-size: 3.5vw;
  }
  .area .data3 p {
    font-size: 3vw;
  }
  ul.hazardmap {
    margin: 30px auto 0;
  }
}
.project {
  width: 100%;
  padding: 120px 0 100px;
  background: #efe6ed;
}
.project h3 {
  margin: 0 auto 30px;
  text-align: center;
  font-size: 1.5vw;
  font-weight: 700;
  letter-spacing: 0.2em;
}
.project h3 + p {
  margin: 0 auto 80px;
  text-align: center;
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 0.1em;
}
.project figure {
  max-width: 680px;
  margin: 0 auto 50px;
}
.project figure figcaption {
  text-align: right;
  font-size: 0.8vw;
}
.project .machidukuri {
  max-width: 800px;
  margin: 0 auto;
}
.shopping {
  width: 100%;
  padding: 120px 0 100px;
  background: #e6e6e6;
}
.shopping h3 {
  margin: 0 auto 50px;
  text-align: center;
  font-size: 1.5vw;
  font-weight: 700;
  letter-spacing: 0.2em;
}
.shopping figure {
  max-width: 1280px;
  margin: 0 auto 100px;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
}
.shopping figure img {
  width: 50%;
}
.shopping figure figcaption {
  width: 50%;
}
.shopping figure figcaption h4 {
  margin: 0 0 20px;
  padding: 0 0 10px 40px;
  border-bottom: 1px solid #333;
  color: #781723;
  font-size: 2vw;
  font-weight: 700;
  line-height: 1.2;
}
.shopping figure figcaption p {
  padding: 0 0 0 40px;
  line-height: 1.6;
}
.shopping figure figcaption p small {
  margin: 20px 0 0;
  display: block;
}
.shopping ul {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.shopping ul li {
  width: 48%;
  position: relative;
}
.shopping ul li h4 {
  margin: 0 auto 10px;
  padding: 0 0 10px;
  border-bottom: 1px solid #000;
  color: #781723;
  font-size: 1.5vw;
  font-weight: 700;
}
.shopping ul li p {
  text-align: right;
}
.shopping ul li p small {
  margin: 20px 0 0;
  display: block;
}
@media(max-width: 767px) {
  .project {
    padding: 50px 20px 40px;
  }
  .project h3 {
    font-size: 4.5vw;
  }
  .project h3 + p {
    margin: 0 auto 30px;
    text-align: left;
    font-size: 3vw;
  }
  .project figure {
    margin: 0 auto 30px;
  }
  .project figure figcaption {
    font-size: 2vw;
  }
  .shopping {
    padding: 50px 20px 40px;
  }
  .shopping h3 {
    margin: 0 auto 30px;
    font-size: 4.5vw;
  }
  .shopping figure img {
    width: 100%;
  }
  .shopping figure {
    margin: 0 auto 30px;
  }
  .shopping figure figcaption {
    width: 100%;
  }
  .shopping figure figcaption h4 {
    margin: 10px 0;
    padding: 0 0 10px;
    font-size: 5.5vw;
  }
  .shopping figure figcaption p {
    padding: 0;
    font-size: 3vw;
  }
.shopping figure figcaption p small {
  margin: 10px 0 0;
}
  .shopping ul li {
    width: 100%;
    margin: 0 auto 20px;
  }
  .shopping ul li h4 {
    margin: 0 0 10px;
    padding: 0 0 10px;
    font-size: 5vw;
  }
  .shopping ul li p {
    padding: 0;
    font-size: 3vw;
  }
  .shopping ul li p small {
    margin: 10px 0 0;
  }
}