@charset "UTF-8";
/*----------------------------
* setting
*----------------------------*/

html, body {
  height: 100%;
  margin: 0;
}
html { font-size: 62.5%; }
body{
  font-family: "Noto Sans JP", sans-serif;
  background-color: #119a88;
  line-height: 2;
  font-weight: 500;
  background-image: url(../img/body_bg.png);
  background-size: cover;
}

section{
  padding:5% 2%;
}
.pc-only{display: block !important;}
.sp-only{display: none !important;}
@media screen and (max-width:767px) {
  .pc-only{display: none !important;}
  .sp-only{display: block !important;}
}
.text-center{
  text-align: center;
}
h3{
  border-top: dotted 1px #009989;
  border-bottom: dotted 1px #009989;
  padding: 6px 0;
  font-size: 1.5rem;
  text-align: center;
  margin-top: 20px;
}
h3 span{
  color: #009989;
  padding-left: 10px;
}
audio {
    width: 100%;
}
.bnr{
  max-width: 464px;
  text-align: center;
  margin: 20px auto 0;
}
/*mgt *************************************************/
.mgt20{margin-top: 20px !important;}
.mgt30{margin-top: 30px !important;}
.mgt40{margin-top: 40px !important;}
/*color *************************************************/
.white{color:#fff !important;}
.black{color:#111 !important;}
.pink{color:#f14889 !important;}
.yellow{color:#d09a00 !important;}
.green{color:#4ea544 !important;}
.blue{color:#00a0ea !important;}
.red{color:#de3427 !important;}

/*Ct *************************************************/
.ContentsWrap{
  max-width: 1440px;
  display: flex;
  margin: 0 auto;
  height: 100vh;   
}

@media screen and (max-width:767px) {
  .ContentsWrap{
    max-width: 100%;
    display: block;
  }
}

.LogoArea{
  max-width: 840px;
  width: 43.75vw;   
  flex-shrink: 0; 
  display: flex;
  justify-content: center;
}

@media screen and (max-width:767px) {
  .LogoArea{
    max-width: 100%;
    width: 100%;
  }
}

.LogoArea img{
  width: 43.75vw;
  max-width: 840px;
  height: auto;
  max-height: 43.75vw;
  display: block;
}

@media screen and (max-width:767px) {
  .LogoArea img{
    width: 100vw;
    height: auto;
    max-height:auto;
  }
}

.MainArea{
  width: 560px; 
  overflow-y: auto;
  scrollbar-width: none;    
  -ms-overflow-style: none; 
  box-sizing: border-box;
  background-color: #fff;
  box-shadow: 0px 0px 15px 0px rgba(100, 100, 100, 0.55);
}
.MainArea::-webkit-scrollbar {
  display: none;
}
.MainArea img{
  width:100%;
}
@media screen and (max-width:767px) {
  .MainArea{
    width:100%;
  }
}

.MainArea .CtWrap{
  padding: 20px;
  font-size: 1.6rem;
  width: 100%;
}
.MainArea .CtWrap img{
  width: 100%;
}

.MainArea .CtWrap p{
  margin-top: 20px;
}
@media screen and (max-width:767px) {
  .MainArea .CtWrap p{
    padding: 0 20px;
  }
}

.themeTtl{
  display: flex;
  margin: 15px 0;
  padding-left: 15px;
  font-size: 2rem;
}

@media screen and (max-width:767px) {
  .themeTtl{
    display: block;
    line-height: 1.4;
    font-size: 2.4rem;
  }
}
.themeTtl .Icon{
  background-color: #ddd;
  border-radius: 0 20px 20px 0;
  padding: 7px 15px 0;
  font-size: 1.2rem;
  margin-right: 15px;
}

@media screen and (max-width:767px) {
  .themeTtl .Icon{
    padding: 4px 0;
    text-align: center;
    font-size: 1.2rem;
    margin-right: 0;
    margin-bottom: 10px;
  }
}

.nameWrap{
  display: flex;
  gap:25px;
  align-items: center;
  border-top:solid 1px #009989;
  border-bottom:solid 1px #009989;
  padding: 20px 20px;
}

.nameWrap .Icon img{
  max-width: 68px;
}

.audioTtl{
  color: #009989;
  text-align: center;
}


#pageTop {
  position: fixed;
  bottom: 50px;
  right: 20px;
  z-index: 5000;
}
#pageTop i {
  padding-top: 6px
}
#pageTop a {
  display: block;
  z-index: 999;
  padding: 5px 0 0 0px;
  border-radius: 30px;
  width: 32px;
  height: 32px;
  background-color: #000;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

footer{
  background-color: #009989;
  color: #fff;
  text-align: center;
  padding: 6px 0;
  font-size:1.2rem;
}

.Talktheme{border: solid 2px #eee;padding: 20px;}
.Talktheme span{color:#009989;}
.SubTtl{background-color: #009989;color: #fff;padding: 3px 15px;border-radius: 25px;}