@charset "utf-8";
/* CSS Document */
.main {
  position: relative;
  overflow: hidden;
}
.main-spbg {
  position: absolute;
  z-index: -1;
  width: 100%;
  left: 0;
  top: 0;
  right: 0;
  margin: auto;
}
.main-pcbg {
  display: none;
}
@media (min-width: 900px) {
  .main-pcbg {
    display: block;
    position: absolute;
    z-index: -1;
    top: -30vh;
    left: 0;
    right: 0;
    margin: auto;
  }
  .main-spbg {
    display: none;
  }
}
.section-top {
  background-image: url("../image/weaving/sp-teori_top_image.jpeg");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%;
  height: 260px;
  position: relative;
}
.section-top h2 {
  letter-spacing: 2px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-weight: 500;
  font-size: 2.4rem;
  font-family: 'Noto Sans JP', sans-serif;
  color: #FFF;
}
.section-top h2 span {
  font-size: 1.4rem;
  font-family: 'Afacad', sans-serif;
}
@media (min-width: 900px) {
  .section-top {
    background-image: url("../image/weaving/teori_top_image.jpeg");
    height: 400px;
  }
  .section-top h2 {
    border-bottom: solid 2px #FFF;
    padding-bottom: 4px;
    font-size: 3.6rem;
  }
  .section-top h2 span {
    font-size: 2rem;
  }
}
.section-calendar h2 {
  letter-spacing: 2px;
  padding: 30px 0 30px 0;
}
.section-calendar img {
  width: 320px;
}
@media (min-width:600px) and (max-width:899px) {
  .section-calendar h2 {
    padding: 60px 0 50px 0;
  }
  .section-calendar img {
    width: 600px;
  }
}
@media (min-width: 900px) {
  .section-calendar h2 {
    padding: 80px 0 60px 0;
  }
  .section-calendar img {
    width: 700px;
    
  }
}
.section-information h2 {
  letter-spacing: 2px;
  padding: 30px 0 10px 0;
}
.section-information ul li {
  list-style: none;
}
.section-information_time {
  width: 300px;
  margin: auto;
  padding: 20px 0;
  text-align: left;
  border-bottom: solid 2px #eeced5;
  font-size: 1.6rem;
  font-weight: 400;
  line-height: 2.8rem;
}
@media (min-width:600px) and (max-width:899px) {
  .section-information h2 {
    letter-spacing: 2px;
    padding: 60px 0 30px 0;
  }
  .section-information_time {
    width: 600px;
  }
}
@media (min-width: 900px) {
  .section-information h2 {
    padding: 80px 0 40px 0;
  }
  .section-information_time {
    width: 600px;
  }
}
.section-about h2 {
  letter-spacing: 2px;
  padding: 30px 0 30px 0;
}
.section-about .img-pc {
  display: none;
}
.section-about .img-sp {
  width: 300px;
  height: 200px;
  object-fit: cover;
}
.section-about_description {
  width: 80%;
  min-width: 300px;
  text-align: left;
  margin: auto;
  padding: 30px 0;
  font-weight: 400;
  line-height: 2.8rem;
}
.section-about_teoriki-description {
  width: 300px;
  text-align: left;
  margin: auto;
  padding: 30px 0;
  font-weight: 400;
  line-height: 2.8rem;
}
@media (min-width:600px) and (max-width:899px) {
  .section-about h2 {
    letter-spacing: 2px;
    padding: 60px 0 50px 0;
  }
  .section-about .img-sp {
    display: none;
  }
  .section-about_description {
    text-align: center;
  }
  .section-about .img-pc {
    display: block;
    margin: auto;
    width: 600px
  }
  .section-about_teoriki-image .img-pc {
    display: block;
    width: 340px;
    height: 224px;
  }
  .section-about_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 30px;
    gap: 40px;
  }
}
@media (min-width: 900px) {
  .section-about h2 {
    padding: 80px 0 60px 0;
  }
  .section-about .img-sp {
    display: none;
  }
  .section-about .img-pc {
    display: block;
    width: 940px;
    height: 304px;
  }
  .section-about_description {
    width: 690px;
    text-align: center;
    padding: 60px 0;
  }
  .section-about_teoriki-description {
    width: 408px;
  }
  .section-about .img-pc {
    width: 820px;
    height: 260px;
    margin: auto;
    object-fit: cover;
    object-position: center;
  }
  .section-about_flex {
    display: flex;
    justify-content: center;
    gap: 70px;
  }
  .section-about_teoriki-image .img-pc {
    width: 340px;
    height: 224px;
  }
}
.section-profile {
  background-color: #eddee1;
}
.section-profile h2 {
  letter-spacing: 2px;
  padding: 60px 0 40px 0;
}
.kodato {
  width: 80%;
  min-width: 300px;
  text-align: left;
  margin: auto;
}
.section-profile h3 {
  font-size: 2rem;
  padding-bottom: 20px;
  margin-left: -10px;
}
.section-profile_description {
  padding: 20px 0 60px 0;
}
@media (min-width: 900px) {
  .section-profile {
    margin-top: 80px;
  }
  .section-profile h2 {
    padding: 60px 0 40px 0;
  }
  .section-profile h3 {
    font-size: 2.4rem;
    padding-bottom: 20px;
    margin-left: -20px;
  }
  .kodato {
    width: 770px;
  }
  .section-profile_description {
    padding: 20px 0 60px 0;
  }
}
.flame {
  position: relative;
  display: inline-block;
}
.section-menu h2 {
  letter-spacing: 2px;
  padding: 30px 0 30px 0;
}
.section-menu_teorikouza {
  padding-top: 12px;
}
.section-menu_teorikouza img {
  width: 300px;
  height: 200px;
  object-fit: cover;
}
.section-menu_teorikouza li {
  position: relative;
}
.section-menu_teorikouza h3 {
  position: absolute;
  font-size: 1.6rem;
  font-weight: 500;
  background-color: #e3c2c5;
  width: 146px;
  top: -12px;
  left: 0;
  padding: 5px
}
.teorikouza-description {
  width: 70%;
  min-width: 300px;
  text-align: left;
  margin: auto;
  padding: 30px 0;
  font-weight: 400;
  line-height: 2.8rem;
}
.teorikouza-title {
  font-size: 1.8rem;
  padding-bottom: 30px;
}
@media (min-width:600px) and (max-width:899px) {
  .section-menu h2 {
    padding: 60px 0 30px 0;
  }
  .teorikouza-description {
    padding-top: 0;
    margin: 0;
  }
  .section-menu_teorikouza li {
  list-style: none;
  }
  .teorikouza-description, .teorikouza-text {
    width: 300px;
  }
  .section-menu_teorikouza-flex {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
  }
  .section-menu_teorikouza {
    padding-top: 0;
  }
  .teorikouza-title {
    padding: 20px 0 20px;
  }
}
@media (min-width: 900px) {
  .section-menu h2 {
    padding: 80px 0 60px 0;
  }
  .section-menu_teorikouza img {
    width: 346px;
    height: 220px;
  }
  .section-menu_teorikouza-flex {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 70px;
  }
  .section-menu_teorikouza {
    padding-top: 0;
  }
  .teorikouza-description {
    width: 352px;
    margin: 0;
    padding: 0;
  }
  .teorikouza-title {
    padding-bottom: 20px;
    padding-top: 0;
  }
}
.section-gallery h2 {
  letter-spacing: 2px;
  padding-bottom: 30px;
}
.slider {
  width: 300px;
  height: 200px;
  margin: 0 auto;
}
.slider img {
  width: 100%; /*スライダー内の画像を横幅100%に*/
  height: auto;
}
@media (min-width:600px) and (max-width:899px) {
  .section-gallery h2 {
    padding: 30px 0 50px 0;
  }
  .slider {
    width: 600px;
  }
}
@media (min-width: 900px) {
  .section-gallery h2 {
    padding: 80px 0 60px 0;
  }
  .slider {
    display: flex;
    justify-content: center;
    gap: 36px;
  }
}
/*slickのJSで書かれるタグ内、スライド左右の余白調整*/
.slider .slick-slide {
  margin: 0 10px;
}
/*矢印の設定*/
/*戻る、次へ矢印の位置*/
.slick-prev, .slick-next {
  position: absolute; /*絶対配置にする*/
  top: 42%;
  cursor: pointer; /*マウスカーソルを指マークに*/
  outline: none; /*クリックをしたら出てくる枠線を消す*/
  border-top: 2px solid #666; /*矢印の色*/
  border-right: 2px solid #666; /*矢印の色*/
  height: 15px;
  width: 15px;
}
.slick-prev { /*戻る矢印の位置と形状*/
  left: -1.5%;
  transform: rotate(-135deg);
}
.slick-next { /*次へ矢印の位置と形状*/
  right: -1.5%;
  transform: rotate(45deg);
}
/*ドットナビゲーションの設定*/
.slick-dots {
  text-align: center;
  margin: 20px 0 0 0;
}
.slick-dots li {
  display: inline-block;
  margin: 0 5px;
}
.slick-dots button {
  color: transparent;
  outline: none;
  width: 8px; /*ドットボタンのサイズ*/
  height: 8px; /*ドットボタンのサイズ*/
  display: block;
  border-radius: 50%;
  background: #ccc; /*ドットボタンの色*/
}
.slick-dots .slick-active button {
  background: #333; /*ドットボタンの現在地表示の色*/
}
@media (min-width: 900px) {
  .slick-dots {
    display: none;
  }
  .slider { /*中央寄せ*/
    width: 100%;
  }
}
.section-voice h2 {
  letter-spacing: 2px;
  padding-top: 60px;
}
.section-voice_flex img {
  height: 164px;
}
.section-voice_flex p {
  width: 300px;
  text-align: left;
  margin: auto;
  padding-top: 26px;
  font-weight: 400;
  line-height: 2.8rem;
}
.section-voice_flex {
  padding-top: 30px;
}
.pc-br_voice {
  display: none;
}
@media (min-width:600px) and (max-width:899px) {
  .section-voice h2 {
    padding: 86px 0 50px 0;
  }
  .section-voice_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 0;
    padding-bottom: 30px;
    margin: 0;
    gap: 50px;
  }
  .section-voice_flex p {
    margin: 0;
    padding-top: 0;
  }
}
@media (min-width: 900px) {
  .section-voice h2 {
    padding: 80px 0 60px 0;
  }
  .sp-br_voice {
    display: none;
  }
  .section-voice_flex {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 0;
    padding-bottom: 30px;
    margin: 0;
    gap: 50px;
  }
  .section-voice ul li p {
    width: 542px;
    margin: 0;
    padding: 0;
  }
  .section-tophemodoru {
    margin: 30px auto 60px;
  }
  .pc-br_voice {
    display: block;
  }
}