@charset "utf-8";

/* ===================================================
	charm2 CSS
====================================================== */

#contents_wrap { font-size: 18px;}

span.tit_en { display: block; opacity: .4; font-size: 14px; font-style: italic;}
.tit_color { color: #729926 !important;}

#sec_lead { width: 100%; margin-bottom: 150px;}
#sec_lead .sec_lead_txt { width: 100%; padding: 170px 0 140px; background: url(../../charm/img2/lead_bg.png)no-repeat left bottom; }
#sec_lead .sec_lead_txt .inner_md { display: flex; flex-direction: row-reverse; justify-content: center; line-height: 2; min-height: 540px;}
#sec_lead h2 { font-size: 40px; line-height: 1.5; margin: 0 0 0 50px; font-feature-settings: initial; writing-mode: tb-rl; writing-mode: vertical-rl;}
#sec_lead h2 .tit_en { margin: 0 0 0 40px;}
#sec_lead .sec_lead_txt p { font-feature-settings: initial; writing-mode: tb-rl; writing-mode: vertical-rl;}

#sec_lead .lead_slide {
  display: flex;
  overflow: hidden;
  width: 100%;
}

#sec_lead .lead_slide .track {
  display: flex;
  flex-shrink: 0;
  width: auto;
}

#sec_lead .lead_slide img {
  width: 700px;
  height: 500px;
  object-fit: cover;
}

#sec_lead .lead_slide .track > div {
  width: 700px;
  height: 500px;
  flex-shrink: 0;
}

@keyframes slide-right {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(0); }
}

@keyframes slide-left {
  0% { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

#lead_slide01 .track {
  animation: slide-left 90s linear infinite;
}

#lead_slide02 .track {
  animation: slide-right 90s linear infinite;
}

#sec_lead .link_btn1 { width: 260px; margin: 60px auto 0;}
#sec_lead .link_btn1 img { margin: 0 15px 0 10px;}
#sec_lead .link_btn1::after { background: #729926;}
#sec_lead .link_btn1 span.arrow::after { background: #729926;}
#sec_lead .link_btn1 span.arrow::before { background: #729926;}

@media screen and (max-width: 600px) {

  #contents_wrap { font-size: 16px;}
  span.tit_en { font-size: 12px;}

  #sec_lead { margin-bottom: 100px;}
  #sec_lead .sec_lead_txt { padding: 80px 0 50px; background-size: 80%; background-position: left -30% bottom 20px;}
  #sec_lead .sec_lead_txt .inner_md { display: block; min-height: auto;}
  #sec_lead h2,#sec_lead .sec_lead_txt p { font-feature-settings: inherit; writing-mode: inherit; writing-mode: inherit;}
  #sec_lead h2,#sec_lead h2 .tit_en { margin-left: 0;}
  #sec_lead h2 { margin: 0 0 30px; font-size: 24px;}
  #sec_lead h2 .tit_en { margin: 0 0 20px;}

  #sec_lead .lead_slide .track > div {
    width: 266px;
    height: 190px;
  }

  #sec_lead .lead_slide img {
    width: 266px;
    height: 190px;
  }
  
  #sec_lead .link_btn1 { margin: 40px auto 0}
}

/* ---------------------------------------------------
movie_col
------------------------------------------------------ */
#movie_col {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1010;
	display: none;
	width: 100%;
	height: 100%;
	padding: 80px 0;
	overflow: hidden;
	background: #000;
}
#movie_col .btn_movie {
	position: absolute;
	top: 20px;
	right: 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border: 3px solid #fff;
	border-radius: 50%;
}
#movie_col .btn_movie::before,
#movie_col .btn_movie::after {
	width: 25px;
	height: 6px;
	content: "";
	background: #fff;
}
#movie_col .btn_movie::before {
	transform: rotate(45deg);
}
#movie_col .btn_movie::after {
	margin: -6px 0 0;
	transform: rotate(-45deg);
}
#movie {
	position: static;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100%;
	margin: 0;
	overflow: hidden;
}

@media screen and (max-width: 600px) {
	#movie_col .btn_movie {
		top: 10px;
		right: 10px;
		width: 40px;
		height: 40px;
		border-width: 2px;
	}
	#movie_col .btn_movie::before,
	#movie_col .btn_movie::after {
		width: 20px;
		height: 4px;
	}
	#movie_col .btn_movie::after {
		margin-top: -4px;
	}
}


/* ---------------------------------------------------
sec1
------------------------------------------------------ */
#sec1 { position: relative; background: url(../../charm/img2/sec1_bg.webp)no-repeat; background-size: cover;}
#sec1 .sec_inner { width: 90%; min-height: 1100px; margin: 0 auto; max-width: 90%;}
#sec1 .sec_inner .tit_wrap { display: table; margin: 0 0 0 auto; padding: 140px 0 0;}
#sec1 .sec_inner h2 { font-size: 40px; line-height: 1.5; font-feature-settings: initial; writing-mode: tb-rl; writing-mode: vertical-rl; color: #fff;}
#sec1 .sec_inner h2 span { opacity: .5;}
#sec1 .sec_inner .tit_en { margin: 0 0 0 40px;}
#sec1 .sec_inner+div { position: absolute;
    left: 5%; 
    bottom: 140px;
    z-index: 1;}
#sec1:after { position: absolute; left: 0; bottom: 0; content: ""; display: block; width: 1129px; height: 949px; background: url(../../charm/img2/sec1_bg_2.png)no-repeat left bottom;}
#sec1 p { margin: -20px 0 0; color: #689215; line-height: 2;}

@media screen and (max-width: 600px) {
  #sec1 { background: url(../../charm/img2/sec1_bg_sp.png)no-repeat; background-size: contain; background-color: #ececec;}
  #sec1 .sec_inner { min-height: auto; padding: 0 0 50px;}
  #sec1 .sec_inner .tit_wrap { padding: 40px 4% 0 0;}
  #sec1 .sec_inner h2 {  font-size: 24px;}
  #sec1 .sec_inner .tit_en { margin: 0 0 0 10px;}
  #sec1 p { margin: 70px 0 0; padding: 0 5%;}
  #sec1 .sec_inner+div { position: static; padding: 20px 0 50px;}
  #sec1:after { display: none;}
}

/* ---------------------------------------------------
sec2
------------------------------------------------------ */
#sec2 { padding: 150px 0 0; width: 1600px; margin: 0 auto; max-width: 90%;}
#sec2 h2 { margin: 0 0 60px; text-align: center; font-size: 40px; line-height: 1.5;}
#sec2 h2 span { margin: 30px 0 0;}

#sec2 .sec2_col1 { display: flex; justify-content: center; flex-direction: row-reverse; align-items: center; margin-bottom: 90px; overflow: hidden;}
#sec2 .sec2_col1 * { min-height: 0; min-width : 0;}
#sec2 .sec_photo { width: 66%;}
.sec2_slide { position: relative; line-height: 0; font-size: 0;}
.sec2_slide .slick-dots {
  position: absolute;
  bottom: -23px;
  right: -30px;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  width: auto;
}
.sec2_slide .slick-dots li { margin: 0;}
.sec2_slide .slick-dots li button { padding: 0;}
.sec2_slide .slick-dots li button:before { width: 20px; height: 20px; content: "●"; font-size: 10px;}
.sec2_slide .slick-dots li button::before{ color: #aaa !important; opacity: 1 !important;}
.sec2_slide .slick-dots li.slick-active button:before{ color: #729926 !important; font-size: 12px;}
.sec2_slide .slick-dotted.slick-slider { margin-bottom: 0;}
#sec2 .sec_txt { width: 22%; box-sizing: content-box; padding: 0 0 0 5%;}
#sec2 p.sec2_time::before { position: absolute; top: -110px; left: 25px; display: block; content: ""; width: 1px; height: 110px; border-left: 1px dotted #729926;}
#sec2 p.sec2_time { position: relative; margin: 0 0 70px; color: #729926; font-style: italic; font-size: 20px;}
#sec2 p.sec2_time span:nth-of-type(1) { font-size: 30px; padding: 0 0 15px 0;}
#sec2 p.sec2_time span:nth-of-type(2) { padding-left: 10px;}
#sec2 p.sec2_time [data-ruby] {
	position: relative;
}
#sec2 p.sec2_time [data-ruby]::before {
	content: attr(data-ruby);
	position: absolute;
	 bottom: -1em;
	left: 0;
	right: 0;
	margin: auto;
	font-size: 0.5em;
  font-size: 14px;
  white-space: nowrap;
}
#sec2 h3 { font-size: 34px; opacity: .5; margin: 0 0 50px; line-height: 1.5;}

#sec2 .sec2_photo_col { width: 1400px; margin: 180px auto 0; max-width: 100%;}
#sec2 .sec2_photo_col .sec_txt { width: 100%;}
#sec2 .sec2_photo_col h3 { font-size: 34px; opacity: .5; text-align: center;}
#sec2 .sec2_photo_col p.sec2_time { text-align: center; margin: 0 0 30px;}
#sec2 .sec2_photo_col p.sec2_time [data-ruby]::before { left: 3em;}
#sec2 .sec2_photo_col p.sec2_time::before { left: 50%;}
#sec2 .sec2_photo_col .sec_photo { width: 100%; display: flex; flex-wrap: wrap; justify-content: space-between;}
#sec2 .sec2_photo_col .sec_photo li:nth-of-type(1) { order: 2; width: 63.6%;}
#sec2 .sec2_photo_col .sec_photo li:nth-of-type(2) { order: 1; width: 35.7%;}
#sec2 .sec2_photo_col .sec_photo li:nth-of-type(3) { order: 3; width: 63.6%; margin-top: 1%;}
#sec2 .sec2_photo_col .sec_photo li:nth-of-type(4) { order: 4; width: 35.7%; margin-top: 1%;}
#sec2 .sec2_photo_col .sec_photo li img { width: 100%;}
#sec2 .sec2_photo_col .sec_photo li img+img { margin-top: 2%;}
#sec2 .sec2_photo_col .sec_photo+p { padding: 60px 0 150px; text-align: center;}

#sec2 .sec2_col2 { display: flex; justify-content: center; align-items: center; margin-bottom: 90px; overflow: hidden;}
#sec2 .sec2_col2 * { min-height: 0; min-width : 0;}
#sec2 .sec2_col2 .sec_txt { width: 22%; box-sizing: content-box; padding: 0 5% 0 0;}
#sec2 .sec2_col2.last { flex-wrap: wrap;}
#sec2 .sec_photo+ul { display: flex; justify-content: space-between; width: 100%; margin-top: 100px;}
#sec2 .sec_photo+ul li { width: 33%;}
#sec2 .sec_photo+ul li img { width: 100%;}

@media screen and (max-width: 600px) {
  #sec2 { padding: 100px 0 0;}
  #sec2 h2 { margin: 0 0 110px; font-size: 24px;}
  #sec2 h2 span { margin: 10px 0 0;}

  #sec2 .sec2_col1,
  #sec2 .sec2_col2 { display: block; overflow: inherit;}
  #sec2 .sec_txt,
  #sec2 .sec2_col2 .sec_txt { width: 100%; margin: 0 0 30px; padding: 0;}
  #sec2 p.sec2_time { margin: 0 0 30px; text-align: center;}
  #sec2 p.sec2_time [data-ruby] { position: static;}
  #sec2 p.sec2_time::before { top: -60px; height: 60px; left: 50%;}
  #sec2 h3,
  #sec2 .sec2_photo_col h3 { margin: 0 0 20px; font-size: 22px; text-align: center;}
  #sec2 .sec_photo { width: 100%;}
  #sec2 .sec_photo .sec2_slide { width: 95%;}
  #sec2 .sec2_slide:not(.slick-dotted) { width: 100%;}
  #sec2 .sec2_slide .slick-dots { right: -7%;}
  #sec2 .sec2_col1 { margin-bottom: 120px;}
  #sec2 .sec2_photo_col .sec_photo+p { padding: 30px 0 100px; text-align: left;}
  #sec2 .sec2_photo_col { margin-top: 90px;}
  #sec2 .sec_photo+ul { margin-top: 1%;}
}

/* ---------------------------------------------------
sec3
------------------------------------------------------ */
#sec3 { padding: 170px 0 120px; background: url(../../charm/img2/bg.gif);}
#sec3 h2 { margin: 0 0 60px; text-align: center; font-size: 40px; line-height: 1.5;}
#sec3 .sec_col { display: flex; justify-content: space-between; padding: 50px 4%; border: 1px solid #ccc; background-color: rgba(255, 255, 255, .5); align-items: flex-start;}
#sec3 .sec_col div {
	width: 54%;
}
#sec3 .sec_col h3 {
	margin: 0 0 25px;
	font-size: 32px;
	line-height: 1;
}
#sec3 .sec_col div img {
	display: table;
	margin: 30px 0 0 auto;
}
#sec3 .sec_col > img {
	width: 40%;
}

@media screen and (max-width: 600px) {
  #sec3 h2 { margin: 0 0 40px; font-size: 24px;}
  #sec3 h2 span { margin: 10px 0 0;}
  #sec3 { padding: 80px 0 60px;}

  #sec3 .sec_col {
		flex-wrap: wrap;
		padding: 30px 5%;
	}
	#sec3 .sec_col > img {
		order: 2;
		width: 100%;
	}
	#sec3 .sec_col div {
		order: 1;
		width: 100%;
		margin: 0 0 20px;
	}
	#sec3 .sec_col h3 {
		margin: 0 0 10px;
		font-size: 22px;
		line-height: 1.5;
	}
	#sec3 .sec_col div img {
		width: 180px;
		margin: 20px 0 0 auto;
	}
}

/* ---------------------------------------------------
sec4
------------------------------------------------------ */
#sec4 { padding: 170px 0 120px; }
#sec4 h2 { margin: 0 0 60px; text-align: center; font-size: 40px; line-height: 1.5;}
#sec4 h2+p { margin: 0 0 95px; text-align: center;}
#sec4 img+p { margin: 80px 0 0; font-size: 34px; color: #729926; text-align: center;}

@media screen and (max-width: 600px) {
  #sec4 h2 { margin: 0 0 40px; font-size: 24px;}
  #sec4 h2 span { margin: 10px 0 0;}
  #sec4 { padding: 80px 0 60px;}
  #sec4 h2+p { margin: 0 0 40px; text-align: left;}
  #sec4 img+p { margin: 30px 0 0; font-size: 24px;}
}