@charset "UTF-8";
/*-------------------------------bede/kanon common-------------------------------*/
body {
font-family: "Noto Serif JP", serif;
position: relative;
/* background-color: #F3F3F3; */
}

body a:hover {
  opacity: 0.7;
}

footer{
  background-color: #004F42;
  font-family: Noto Sans JP;
  font-weight: 400;
}

.footer a:visited,.footer a:link{
  color: #ffffff;
}

.footer_body {
margin: 0 auto;
}

.footer_body #copyright {
font-size: 0.9em;
line-height: 18px;
}

.common-footer ul {
margin: 0 auto;
width: 700px;
}

.common-footer li {
float: left;
padding: 10px;
}


.footer-sitemap{
margin-bottom: 50px;
width: 900px;
}

#unei {
text-align: left;
float: left;
color: #ffffff;
}

#copyright {
vertical-align:bottom;
color: #ffffff;
}


.common-footer {
  background: #004F42;
  padding: 28px 20px 16px;
  text-align: center;
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 0;
  margin: 0 auto 16px !important;
  padding: 0;
  list-style: none;
}


.footer-nav li {
  position: relative;
  padding: 0 14px;
  line-height: 1;
}


.footer-nav li::after {
  content: "";
  width: 1px;
  height: 12px;
  background: rgba(255, 255, 255, 0.7);

  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}

.footer-nav li:last-child::after {
  display: none;
}

.footer-nav a {
  color: #fff;
  font-size: 13px;
  text-decoration: none;
  transition: opacity 0.3s;
}

.footer-nav a:hover {
  opacity: 0.7;
}


.footer-company {
  font-size: 10px;
  line-height: 2;
  color: #ffffff;
}

.copyright {
  font-size: 10px;
}

.footer-copy{
  display: flex;
  justify-content: center;
  gap: 40px;
  color: #ffffff;
  font-size: 10px;

}

#privacy-policy p {
padding-top: 20px;
}

#privacy-policy dt {
padding-top: 20px;
line-height: 2em;
font-weight: bold;
}

#privacy-policy dl {
padding-bottom: 30px;
}

#fb-root {
margin-top:50px;
}

#fb-timeline {
float: left;
width: 400px;
}

#tw-timeline {
margin-top:50px;
float: right;
width: 400px;
}


/* ------------------------------- clearfix area ----------------------------------- */
.clearfix:after {
content         : ".";
display         : none;
height          : 0;
font-size       : 0;
clear           : both;
visibility      : hidden;
}


* html .clearfix {
height          : 1%;
}

.clearfix{
  display: none;
}


/* ----------------------------- header - */

/*----page-top----*/
#page-top {
position: fixed;
bottom: 50px;
right: 50px;
}

#page-top a {
color: #fff;
display: block;
font-size: 1em;
background-color: #000;
width: 50px;
padding: 12px 2px;
border-radius: 50%;
  -moz-border-radius: 50%;
  -webkit-border-radius: 50%;
}
.pagetop {
	display: none;
}
/* ------------------------------- footer area ----------------------------------- */

/* ------------------------------- 共通 ----------------------------------- */
.release_rss_icon{
  display: none;
}

.sp{
  display: none;
}

.sp-br {
  display: none;
}

body{
  letter-spacing: 0.1em;
  line-height: 1.6;
  font-weight: 500;
  font-size: 14px;
}

p{
  margin: 0;
}

h2{
  color:#004F42 ;
  border-left: 5px solid #004F42 !important;
  font-size: 20px !important;
  padding-top:0 !important;
  padding-bottom: 0 !important;
}

h3{
  margin-bottom: 40px;
}

#release .article div,#release .article p,#release .article span{
background-color: #F3F3F3;
  font-family: Noto Sans JP !important;
  font-size: 14px;
  font-weight: 500;
}

.page-btn{
  background-color: #004F42;
  display: block;
  width: 209px;
  padding: 8px 0;
  position: relative;
  font-size: 12px;
  text-align: center;
  margin: 0 auto;
}

.page-btn a{
  color: #ffffff !important;
  text-decoration: none;
}

.page-btn a::after{
  content: ">";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}

.border-line{
  border-bottom: 1px solid #E2E2E2;
  width: 57px;
  height: 1px;
  margin-bottom: 13px;
}

.border-line-long{
  border-bottom: 1px solid #E2E2E2;
  height: 1px;
  margin: 60px 0;
}

h3 {
  position: relative;
  padding-left: 14px;
  font-size: 20px;
  font-weight: 800;
  color: #004F42;
}

h3::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 5px;
  height: 32px;
  background-color: #004F42;
  transform: translateY(-50%);
}

.bold{
  font-weight: 700;
}


/* ------------------------------- トップページ ----------------------------------- */

/* トップニュース */
.top_news_body{
  padding: 20px 0 60px;

}

.top_news_body li{
  position: relative;
  margin-left: 0 !important;
  padding-left: 10px;
  letter-spacing: 0;
}

.top_news_body li::after{
  content: ">";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}

.top_rss_link{
  background-color: #004F42;
  display: block;
  width: 209px;
  margin: 0 auto;
  text-align: center !important;
  padding: 8px 0;
  position: relative;
}

.top_rss_link a{
  color: #ffffff !important;
  font-size: 12px;
  font-weight: 400;
  text-decoration: none !important;
}

.top_rss_link a::after{
  content: ">";
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}

/* コンセプト */
.concept{
  text-align: center;
  margin-bottom: 60px;
}

.top-page h1{
  font-size: 24px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  color: #004F42;
  font-weight: bold;
  margin-bottom: 22px;
}

.concept-text{
  font-size: 14px;
  line-height: 1.8;
  margin-bottom: 34px;
}

h1{
  font-size: 30px;
}

/* 講師紹介 */
.onomasatoshi-inner{
  display: flex;
  gap:42px;
  margin-bottom: 40px;
}

.onomasatoshi-img img{
  width: 210px;
}

.instructors-title{
  margin: 60px 0 20px;
}

.instructors .lead{
  font-size: 14px;
  margin-bottom: 40px;
}


.instructors-name{
  font-size: 24px;
  font-weight: 700;
  color: #004F42;
  margin-bottom: 13px;
  letter-spacing: 0.06em;
}

.instructors-name span{
  font-size: 10px;
  font-weight: 700;
}

.instructors-sab{
  font-size: 14px;
  color: #004F42;
  font-weight: 700;
  margin-bottom: 27px;
}

.instructors-point{
  font-size: 14px;
  margin-bottom: 25px;
  letter-spacing: 0.1em;
}

.achievements{
  background-color: #EDEDED;
  padding: 22px 0 33px;
  border-radius: 6px;
  margin-bottom: 60px;
}

.achievements-title{
  font-size: 20px;
  color: #004F42;
  font-weight: 700;
  margin: 0 0 24px 20px;

}

.achievements-title span{
  font-size: 10px;
  font-weight: 700;
  color: #004F42;
  margin-left: 20px;

}
.achievements-sub-title{
  font-size: 12px;
  font-weight: 700;
  color: #004F42;
  margin-bottom: 12px;
}

.achievements-text{
  font-size: 11px;
  font-weight: 500;
}

.achievements-list{
  display: flex;
}

.achievements-list li{
  flex: 1;
  padding: 0 20px;
  border-right: 1px solid #ffffff;
  text-align: center;
}

.achievements-list li:last-child{
  border-right: none;
}

.achievements-list li img{
  width: 33px;
  margin-bottom: 11px;
}

/* 講師紹介 （市村先生、YOKO先生）*/

.sub-teacher{
  align-items: center;
}

.sub-teacher .instructors-name{
  font-size: 20px;
}

.sub-teacher-pc{
  margin-bottom: 60px;
}

/* ------------------------------- スクールページ ----------------------------------- */
/* スクール紹介 */
.school-section{
  margin-bottom: 80px;
}

.school-lead{
  margin-bottom: 40px;
}

.school-lead p{
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin-bottom: 15px;
}

.school-section-title{
  margin-right: 12px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: #004F42;
}

.school-section-title-flex{
  display: flex;
  align-items: center;
  margin-bottom: 20px;
}


.school-section-title-small{
  font-size: 16px;
  font-weight: 400;
  color: #AEAEAE;
  letter-spacing: -0.03em;
  margin-right: 20px;
  flex-shrink: 0;
}
.school-section-title-flex::after {
  content: "";
  height: 1px;
  background-color: #D8D8D8;
  flex: 1;
}

.strengths-block{
  margin-bottom: 40px;
}

.strengths-block li{
  background-color: #EDEDED;
  margin-bottom: 20px;
  padding: 16px 20px 24px;
  border-radius: 6px;
}

.strengths-block li div{
  display: flex;
  gap:20px;
  margin-bottom: 8px;
}

.point-notice{
  font-size: 12px;
  margin-top: 8px;
}

.point-title{
  padding-top: 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing:0.1em;
  color: #004F42;
}

.point-number{
  font-size: 14px;
  color: #004F42;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.point-number span{
  font-size: 24px;
}

.point-text{
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.school-section .page-btn{
  width: 257px;
}

/* 講師紹介 */
.teacher-section{
  margin-bottom: 80px;
}

.teacher-section-ono{
  display: flex;
  gap:20px;
  margin-bottom: 40px;
}

.teacher-section-ono img{
  width: 210px;
}

.teacher-name{
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}

.teacher-text{
  font-size: 14px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.teacher-other{
  margin-bottom: 20px;
}

/* 会員料金 */

.price-table{
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0 ;
  font-family: Noto Sans JP;
  font-weight: 400;
}

.price-table th,
.price-table td{
  border: 1px solid #C7C7C7;
  padding: 17px 12px;
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  text-align: left;
  vertical-align: middle;
}

.price-table th{
  background-color: #DEDEDE;
  font-weight: 400;
}

.price-table td{
  background-color: #EDEDED;
}

.price-table th span{
  font-size: 10px;
  font-weight: 400;
}

.course-notes{
  margin-bottom: 80px;
}

.course-notes li{
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.lesson-notes{
  margin-bottom: 40px;
  font-size: 12px;
}

.general-rates-section{
  margin-bottom: 80px;
}

/* ポイントカード */

.apply-section{
  margin-bottom: 60px;
}

.point-card-section .school-section-title-flex::after,
.apply-section .school-section-title-flex::after{
  width: 322px;
}

.point-card-section{
  margin-bottom: 80px;
}

/* 入会申し込み方法 */
.teacher-text{
  margin-bottom: 20px;
}
.apply-block{
  margin-bottom: 20px;
}

.apply-title{
  margin-top: 20px;
}

/* 受講者の声 */

.voice-section{
  margin-bottom: 80px;
}
.voice-section h3{
  margin-bottom: 20px;
}

.voice-section p{
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  font-weight: 500;
  margin-bottom: 20px;
}

.voice-list{
  background-color: #EDEDED;
  padding:10px 20px;
}
.voice-list li{
  position: relative;
  border-bottom:1px solid #ffffff;
  padding: 14px 0 14px 25px;
  font-size: 14px;
}

.voice-list li:last-child {
  border-bottom: none;
}

.voice-list li::before{
  content: "";
  display: inline-block;
  width: 16px;
  height: 15px;
  background-image: url("https://all-in-one-cms.s3-ap-northeast-1.amazonaws.com/sound-s.jp/files/voice-icon.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  left: 0;
  top: 18px;
}

/* アクセス */
.access-section h3{
  margin-bottom: 20px;
}

.access-info{
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.access-block{
  margin-bottom: 20px;
}

.access-section .page-btn{
  position: relative;
}

.access-section .page-btn a::after{
  content: "";
  display: inline-block;
  background-image: url("https://all-in-one-cms.s3-ap-northeast-1.amazonaws.com/sound-s.jp/files/allow.png");
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 19px;
  right: 13px;
  width: 8px;
  height: 8px;
}

/* ------------------------------- 会員の方 ----------------------------------- */

.member-section img{
  height: 60px;
}

/* ------------------------------- レッスン内容 ----------------------------------- */

.lesson-page h3{
  margin-bottom: 20px;
}

.lesson-page-lead{
  font-size: 14px;
  margin-bottom: 40px;
}

.program-section{
  background-color: #EDEDED;
  border-radius: 6px;
  position: relative;
  padding: 30px 0 30px 66px;
  margin: 20px 0 80px;
}

/* 縦線 */
.program-section::before {
  content: "";
  position: absolute;
  top: 40px;
  left: 30px;
  width: 1px;
  height: calc(100% - 180px);
  background-color: #C7C7C7;
  }

/* 丸 */
.program-list-item::before {
  content: "";
  position: absolute;
  top: 10px;
  left: -39px;
  width: 6px;
  height: 6px;
  background-color: #00594d;
  border-radius: 50%;
}

.program-list-item{
  margin-bottom: 30px;
  position: relative;
}

.program-title{
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.6;
  color: #004F42;
  margin-bottom: 8px;
}

.program-text{
  font-size: 12px;
  letter-spacing: 0.1em;
  line-height: 1.6;
}

/* 目的別のレッスン */

.case-section {
  margin-top: 20px;
}

.case-box {
  background-color: #EDEDED;
  border-radius: 6px;
  padding: 16px 20px 24px;
}

.case-box + .case-box {
  margin-top: 20px;
}

.case-title {
  color: #004F42;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.1em;
  padding-bottom: 8px;
  margin-bottom: 8px;
  border-bottom: 1px solid #C7C7C7;
}

.case-text {
  font-size: 12px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  font-weight: 500;
}

/* ------------------------------- よくあるご質問 ----------------------------------- */

#faq #questions{
  display: none;
}

.faq-box {
  background: #EDEDED;
  padding: 20px;
}

.faq-box__question {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-bottom: 16px;
  margin-bottom: 16px;
  border-bottom: 1px solid #cfcfcf;
}

.faq-box__icon {
  width: 32px;
  height: 32px;
  background: #004f42;
  color: #fff;
  font-size: 16px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: serif;
}

.faq-box__question p {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.1em;
}

.faq-box__answer p {
  font-size: 13px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

.answer{
  margin-bottom: 40px !important;
}

.answer h3{
  display: none;
}

/* ------------------------------- 運営会社 ----------------------------------- */

.company-info {
  max-width: 640px;
}

.company-info__item + .company-info__item {
  margin-top: 32px;
}

.company-info__item dt {
  background: #EDEDED;
  color: #004f42;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.1em;
  padding: 5px 0px 5px 14px;
  margin-bottom: 20px;
}

.company-info__item dd {
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin: 0;
  padding: 0 14px;
}

/* ------------------------------- お知らせ ----------------------------------- */

.top_rightArea{
  padding-left:15px !important;
}

.top_rightArea h2{
  font-size: 20px;
}


#release li, .top_news li{
  margin-bottom: 17px;
  margin-left: 10px;
  border-top: 1px solid #E2E2E2;
  padding-top: 17px;
  padding-bottom: 0;
  }

#release ul li::after{
  content: ">";
  position: absolute;
  right: 3px;
  top: 70%;
  transform: translateY(-50%);
}

#release ul li{
  position: relative;
  padding-right: 25px;
}

#release ul li:last-child{
   border-bottom: 1px solid #E2E2E2;
   padding-bottom: 16px;
}

.top_news li:last-child{
   border-bottom: 1px solid #E2E2E2;
   padding-bottom: 16px;
}


 .MsoNormal{
  background-color: #F3F3F3;
}

.article{
  margin: 0;
}

  /* ------------------------------- お問い合わせ ----------------------------------- */

  #inquiry h3{
    font-size: 12px;
    font-weight: 500;
    color: #000;
    border-bottom: 1px solid #c0c0c0;
    padding-bottom: 7px;
    margin-bottom: 5px;
  }

  #inquiry h3::before{
    display: none;
  }

  #inquiry p{
    margin-left: 0 !important;
  }

  /* ------------------------------- ビジター予約 ----------------------------------- */
  .privacy_description{
    font-size: 12px;
  }

