@charset "UTF-8";
@media only screen and (max-width: 48em) {
  .topics_block .wrapper {
    margin: auto;
    padding: 0; 
    width: 100%;
  }
}

.topics_header {
  position: relative;
}

.topics_bg-img {
  position: relative;
}
.topics_bg-img:before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%; 
  background-color: rgba(0, 0, 0, 0.4);
  content: "";
}
@media only screen and (max-width: 48em) {
  .topics_bg-img {
    padding-top: 72%; 
    width: 100%;
      background-position: center center;
  }
  .topics_bg-img img {
    display: none;
  }
}

.topics_title {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  height: 180px; 
  color: #fff;
  text-align: center;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
  font-size: 28px;
  font-size: 2.8rem;
}

.topics_subtitle {
    text-align: center;
    font-size: 22px;
    font-size: 2.2rem;
    font-family: Noto Sans, serif;
    color: #a37e38;
    line-height: 1.8;
    padding: 3% 0 2%;
}

.title_color{
color : #a37e38;
}

@media only screen and (max-width: 48em) {
  .topics_title {
    height: 100px; 
    font-size: 22px;
    font-size: 2.2rem;
  }
    .topics_subtitle {
        font-size: 16px;
        font-size: 1.6rem;
        padding: 4% 0;
    }
}
.topics_title span {
  display: block;
  font-weight: normal;
  font-size: 24px;
  font-size: 2.4rem;
  font-family: "Julius Sans One";
}
@media only screen and (max-width: 48em) {
  .topics_title span {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
.topics_title span.topics_title-min {
    font-family: Noto Sans, serif;
    font-size: 2.2rem;
}
@media only screen and (max-width: 48em) {
  .topics_title span.topics_title-min {
    font-size: 14px;
    font-size: 1.4rem;
  }
}

.main-area_sublead-txt {
    padding-bottom: 1%;
    text-align: center;
    line-height: 2.28;
}
.main-area_sublead-txt:last-child {
    margin-bottom: 3%;
}

@media only screen and (max-width: 48em) {
  .main-area_sublead-txt {
    margin: 3% auto 0;
    max-width: 90%;
    font-size: 12px;
    font-size: 1.2rem;
  }
}
@media only screen and (max-width: 48em) {
  .main-area_sublead-txt span {
      display: none;
  }
}

.topics-box {
  padding: 4% 0;
  background-color: #fff;
}
.topics-box:nth-child(2n) {
  background-color: rgba(131, 167, 75, 0.2);
}
.topics-box:nth-child(2n) .topics-box_img-outer {
  float: right;
}
.topics-box:nth-child(2n) .topics-box_header-inner {
  right: auto; 
  left: 0;
}
@media only screen and (max-width: 48em) {
  .topics-box {
    padding: 0;
  }
}

.topics-box_inner:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}

.topics-box_img-outer {
  position: relative;
  float: left;
  overflow: hidden; 
  width: 50%;
}
@media only screen and (max-width: 54em) {
  .topics-box_img-outer {
    margin-bottom: 6%; 
    width: 100%;
    background-color: #f5f5f5;
  }
}

.topics-box_img {
  font-size: 0;
}
.topics-box_img img {
  float: left; 
  width: 49.8%;
}
.topics-box_img img:nth-child(3n+3) {
  float: right;
}
.topics-box_img img:nth-child(odd) {
  margin-top: 0.3%; 
  margin-top: 0.3%; 
  float: right;
}
.topics-box_img img:nth-child(even) {
  margin-top: 0.3%; 
  margin-top: 0.3%; 
}
.topics-box_img img:first-child {
  margin-bottom: 0.3%; 
  width: 100%;
}

.topics-box_header {
  position: relative; 
  float: left;
  padding-top: 50%;
  width: 50%;
}
@media only screen and (max-width: 54em) {
  .topics-box_header {
    padding-top: 0;
    width: 100%;
  }
}

.topics-box_header-inner {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  max-width: 500px; 
  width: 92.5%;
}
@media only screen and (max-width: 54em) {
  .topics-box_header-inner {
    position: relative;
    padding: 0 4% 8%; 
    max-width: 100%;
    max-height: 100%;
    width: 100%;
  }
}

.topics-box_title {
  margin-bottom: 4%;
  text-align: left;
  font-size: 22px;
  font-size: 2.2rem;
  font-family: Noto Sans, serif;
  line-height: 1.8;
}
@media only screen and (max-width: 54em) {
  .topics-box_title {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 48em) {
  .topics-box_title {
    text-align: center;
  }
}

.topics-box_sub-title {
  margin-bottom: 5.6%;
  font-weight: bold;
  font-size: 20px;
  font-size: 2rem;
  line-height: 1.8;
}
.topics-box_sub-title span {
  display: block; 
  font-size: 13px;
  font-size: 1.3rem;
}
.topics-box_sub-title span:before {
  content: "— ";
}
.topics-box_sub-title span:after {
  content: " —";
}
@media only screen and (max-width: 54em) {
  .topics-box_sub-title {
    font-size: 17px;
    font-size: 1.7rem;
  }
  .topics-box_sub-title span {
    font-size: 11px;
    font-size: 1.1rem;
  }
}

.topics-box_lead-txt {
  margin-bottom: 4.4%;
  color: #5fcc85;
  text-align: center;
  font-weight: bold;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.8;
}
@media only screen and (max-width: 54em) {
  .topics-box_lead-txt {
    font-size: 12px;
    font-size: 1.2rem;
  }
}

.topics-box_description {
	font-size: 13px;
	font-size: 1.3rem;
	font-family: Noto Sans, sans-serif;
	line-height: 2;
	margin-bottom: 15px;
}


@media only screen and (max-width: 54em) {
  .topics-box_description {
    margin-bottom: 4%; 
    font-size: 11px;
    font-size: 1.1rem;
  }
}


.plan-box_description {
	border: 1px solid #5D7E2A;
	padding: 15px;
	font-size: 13px;
	font-size: 1.3rem;
	font-family: Noto Sans, sans-serif;
	line-height: 2;
}

.plan_tit {
	font-size: 15px;
	font-size: 1.5rem;
	color: #5D7E2A;
	font-family: Noto Sans, serif;
	font-weight: 900;
  }

@media only screen and (max-width: 54em) {
  .plan-box_description {
    margin-bottom: 4%; 
    font-size: 11px;
    font-size: 1.1rem;
  }
}

/*== 囲い topics01 ==*/
/*= .topics_subtitle =*/
.restriction-box_subtitle {
    background: #E6EDDB;
}
/*= .topics-box_description =*/
.restriction-box_white {
    background: #fff;
    padding: 15px;
}
.restriction-box_green {
    background: #E6EDDB;
    padding: 15px;
}
/*=　TOPICS#01　部門別 受賞一覧 調整 =*/
@media only screen and (max-width: 48em) {
  .prize {
    padding-bottom: 0;
  }
}