@charset "utf-8";

/*////////////////////////////////////
topic
////////////////////////////////////*/
@media screen and (min-width: 768px){
.topic_menu_area {
	position: relative;
	width: 100%;
	padding: 50px 0;
	background: #EEE;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
}
.topic_menu_place {
	position: relative;
	width: 21%;
	padding: 20px;
	margin: 2%;
	background: #FFF;
}
#topic {
	position: relative;
	width: 100%;
	padding: 50px 0;
	background: #EEE;
}
.topic_area {
	position: relative;
	width: 90%;
	padding: 50px;
	max-width: 1400px;
	margin: 0 auto 50px;
	background: #FFF;
}
.topic_main_photo {
	position: relative;
	width: 100%;
	margin-bottom: 10px;
}
.topic_dayarea {
	position: relative;
	display: inline-block;
	background: #555;
	font-size: 1.4rem;
	padding: 5px 10px;
	border-radius: 5px;
	color: #FFF;
	font-weight: 700;
}
.topic_titlearea {
	position: relative;
	font-size: 1.6rem;
	color: #555;
	font-weight: 400;
}
.topic01 {
	position: relative;
	width: 100%;
	text-align: center;
	margin-bottom: 100px;
}
.topic01 h3 {
	font-size: 3rem;
	font-weight: 700;
	margin-bottom: 1em;
}
.topic01 h4 {
	position: relative;
	font-size: 2.6rem;
	font-weight: 400;
	margin-bottom: 1em;
}
.topic01 h4::before {
	content: "";
	position: absolute;
	width: 30px;
	height: 2px;
	background: #555;
	bottom: -5px;
	left: 50%;
	transform:translateX(-50%);
}
.topic01 p {
	font-size: 1.6rem;
	font-weight: 300;
	line-height: 1.8;
}
.topic02 {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	margin-bottom: 50px;
}
.topic_word_area {
	position: relative;
	width: 40%;
	margin-right: 2%;
	margin-left: 2%;
}
.topic_word_area h3 {
	width: 100%;
	font-size: 2.4rem;
	margin-bottom: 1em;
}
.topic_word_area p {
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: 300;
}
.topic_photo_area {
	position: relative;
	width: 40%;
	margin-left: 2%;
	margin-right: 2%;
}

.topic_photo_area2 {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 50px;
}
.topic_photo {
	position: relative;
	width: 50%;
}
}

@media screen and (min-width: 0px) and (max-width: 767px){
.topic_menu_area {
	position: relative;
	width: 100%;
	padding: 10px 0;
	background: #EEE;
}
.topic_menu_place {
	position: relative;
	width: 90%;
	padding: 20px;
	max-width: 1400px;
	margin: 0 auto 20px;
	background: #FFF;
}
#topic {
	position: relative;
	width: 100%;
	padding: 50px 0;
	background: #EEE;
}
.topic_area {
	position: relative;
	width: 90%;
	padding: 20px;
	max-width: 1400px;
	margin: 0 auto 50px;
	background: #FFF;
}
.topic_main_photo {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic_dayarea {
	position: relative;
	display: inline-block;
	background: #555;
	font-size: 1.4rem;
	padding: 5px 10px;
	border-radius: 5px;
	color: #FFF;
	font-weight: 700;
}
.topic_titlearea {
	position: relative;
	font-size: 1.6rem;
	color: #555;
	font-weight: 400;
}
.topic01 {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic01 h3 {
	font-size: 2.6rem;
	font-weight: 700;
	margin-bottom: 1em;
}
.topic01 h4 {
	position: relative;
	font-size: 2.6rem;
	font-weight: 400;
	text-align: center;
	margin-bottom: 1em;
}
.topic01 h4::before {
	content: "";
	position: absolute;
	width: 30px;
	height: 2px;
	background: #555;
	bottom: -5px;
	left: 50%;
	transform:translateX(-50%);
}
.topic01 p {
	font-size: 1.6rem;
	font-weight: 300;
	line-height: 1.8;
}
.topic02 {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic_word_area {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic_word_area h3 {
	width: 100%;
	font-size: 2.4rem;
	margin-bottom: 1em;
}
.topic_word_area p {
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.8;
	font-weight: 300;
}
.topic_photo_area {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic_photo_area2 {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.topic_photo {
	position: relative;
	width: 100%;
}
}

/*////////////////////////////////////
TOP link
////////////////////////////////////*/
@media screen and (min-width: 768px){
.top_link_area {
	position: relative;
	width: 100%;
	text-align: center;
	padding: 50px 0 0 0;
	display: flex;
	justify-content: center;
}
.top_link {
	position: relative;
	margin:20px;
}
.top_link a {
	position: relative;
	display: inline-block;
	width: 300px;
	padding: 20px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	font-size: 1.8rem;
	font-weight: 700;
	border-radius: 50px;
	background: #0F80D3;
	border: 4px solid #0D4073;
	transition: all 0.3s;
}
.top_link a:hover {
	background:#DCC91C;;
	color: #333;
	box-shadow: 0px 3px 10px 0px rgba(0,0,0,0.3);
}
.top_link a:active {
	position: relative;
	top: 1px;
	left: 1px;
}
.top_link a::before {
	content: '';
	width: 20px;
  	height: 20px;
  	background: #333;
  	border-radius: 50%;
  	position: absolute;
  	top: 0;
  	right: 20px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link a:after {
  	content: '';
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 4px 0 4px 6px;
  	border-color: transparent transparent transparent #fff;
  	position: absolute;
  	top: 0;
  	right: 26px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link a:hover::before {
	right: 16px;
}
.top_link a:hover::after {
	right: 22px;
}

.top_link2 {
	position: relative;
	margin:20px;
	text-align: center;
}
.top_link2 a {
	position: relative;
	display: inline-block;
	width: 200px;
	padding: 10px 20px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: 700;
	border-radius: 50px;
	background: #0F80D3;
	border: 4px solid #0D4073;
	transition: all 0.3s;
}
.top_link2 a:hover {
	background:#DCC91C;;
	color: #333;
	box-shadow: 0px 3px 10px 0px rgba(0,0,0,0.3);
}
.top_link2 a:active {
	position: relative;
	top: 1px;
	left: 1px;
}
.top_link2 a::before {
	content: '';
	width: 20px;
  	height: 20px;
  	background: #333;
  	border-radius: 50%;
  	position: absolute;
  	top: 0;
  	right: 20px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link2 a:after {
  	content: '';
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 4px 0 4px 6px;
  	border-color: transparent transparent transparent #fff;
  	position: absolute;
  	top: 0;
  	right: 26px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link2 a:hover::before {
	right: 16px;
}
.top_link2 a:hover::after {
	right: 22px;
}
}
@media screen and (min-width: 0px) and (max-width: 767px){
.top_link_area {
	position: relative;
	width: 100%;
	text-align: center;
	padding: 20px 0 0 0;
}
.top_link {
	position: relative;
	margin:20px;
}
.top_link a {
	position: relative;
	display: inline-block;
	width: 250px;
	padding: 10px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	font-size: 1.8rem;
	font-weight: 700;
	border-radius: 50px;
	background: #0F80D3;
	border: 4px solid #0D4073;
	transition: all 0.3s;
}
.top_link a:hover {
	background:#DCC91C;;
	color: #333;
	box-shadow: 0px 3px 10px 0px rgba(0,0,0,0.3);
}
.top_link a:active {
	position: relative;
	top: 1px;
	left: 1px;
}
.top_link a::before {
	content: '';
	width: 20px;
  	height: 20px;
  	background: #333;
  	border-radius: 50%;
  	position: absolute;
  	top: 0;
  	right: 20px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link a:after {
  	content: '';
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 4px 0 4px 6px;
  	border-color: transparent transparent transparent #fff;
  	position: absolute;
  	top: 0;
  	right: 26px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link a:hover::before {
	right: 16px;
}
.top_link a:hover::after {
	right: 22px;
}


.top_link2 {
	position: relative;
	margin:20px;
	text-align: center;
}
.top_link2 a {
	position: relative;
	display: inline-block;
	width: 250px;
	padding: 10px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	font-size: 1.6rem;
	font-weight: 700;
	border-radius: 50px;
	background: #0F80D3;
	border: 4px solid #0D4073;
	transition: all 0.3s;
}
.top_link2 a:hover {
	background:#DCC91C;;
	color: #333;
	box-shadow: 0px 3px 10px 0px rgba(0,0,0,0.3);
}
.top_link2 a:active {
	position: relative;
	top: 1px;
	left: 1px;
}
.top_link2 a::before {
	content: '';
	width: 20px;
  	height: 20px;
  	background: #333;
  	border-radius: 50%;
  	position: absolute;
  	top: 0;
  	right: 20px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link2 a:after {
  	content: '';
  	width: 0;
  	height: 0;
  	border-style: solid;
  	border-width: 4px 0 4px 6px;
  	border-color: transparent transparent transparent #fff;
  	position: absolute;
  	top: 0;
  	right: 26px;
  	bottom: 0;
  	margin: auto;
	transition: all 0.3s;
}
.top_link2 a:hover::before {
	right: 16px;
}
.top_link2 a:hover::after {
	right: 22px;
}
}

/*////////////////////////////////////
topic eco2025
////////////////////////////////////*/
@media screen and (min-width: 768px){
#eco01 {
	position: relative;
	width: 100%;
	aspect-ratio:1920/900;
	background: url("../topic/img/eco2025_01.jpg");
	background-size: cover;
}
#eco2026_01 {
	position: relative;
	width: 100%;
	aspect-ratio:1920/900;
	background: url("../topic/img/eco2026_01.jpg");
	background-size: cover;
}
#eco_word_area {
	position: relative;
	width: 100%;
}
#eco_word_area h3 {
	font-size: 3.6rem;
	font-weight: 700;
	margin-bottom: 1em;
}
#eco_word_area h4 {
	font-size: 2rem;
	font-weight: 400;
	margin-bottom: 1em;
	color: #2197AE;
}
#eco_word_area p {
	width: 50%;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.8;
}
#eco_photo_area {
	position: relative;
	width: 100%;
	display: flex;
	justify-content: center;
}

.eco_photo {
	position: relative;
	width: 33.3%;
}
.topic_detail_day {
	position: relative;
	width: 100%;
	text-align: center;
	margin-bottom: 10px;
}
.topic_detail_day span {
	display: inline-block;
	padding: 5px 30px;
	background: rgba(22,50,54,1.00);
	color: #FFF;
	font-size: 1.4rem;
	border-radius: 6px;
}
.topic_detail_title {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
	text-align: center;
}
.topic_detail_title h2 {
	color: rgba(35,72,85,1.00);
	font-size: 3rem;
}
}

@media screen and (min-width: 0px) and (max-width: 767px){
.topic_detail_day {
	position: relative;
	width: 100%;
	text-align: center;
	margin-bottom: 10px;
}
.topic_detail_day span {
	display: inline-block;
	padding: 5px 30px;
	background: rgba(22,50,54,1.00);
	color: #FFF;
	font-size: 1.4rem;
	border-radius: 6px;
}
.topic_detail_title {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
	text-align: center;
}
.topic_detail_title h2 {
	color: rgba(35,72,85,1.00);
	font-size: 2rem;
}
#eco01 {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
#eco2026_01 {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
#eco_word_area {
	position: relative;
	width: 100%;
}
#eco_word_area h3 {
	font-size: 2.6rem;
	font-weight: 700;
	margin-bottom: 1em;
}
#eco_word_area h4 {
	font-size: 1.8rem;
	font-weight: 400;
	margin-bottom: 1em;
	color: #2197AE;
}
#eco_word_area p {
	width: 100%;
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.8;
}
#eco_photo_area {
	position: relative;
	width: 100%;
}
.eco_photo {
	position: relative;
	width: 100%;
}
}
.topic_upday {
	position: relative;
	width: 100%;
	text-align: center;
	margin-bottom: 10px;
}
.topic_upday span {
	display: inline-block;
	background: #555;
	color: #FFF;
	font-size: 1.4rem;
	padding: 5px 10px;
	border-radius: 5px;
}
.topic_up_title {
	position: relative;
	width: 100%;
	text-align: center;
	font-size: 1.8rem;
	margin-bottom: 10px;
}