@charset "utf-8";

/* sp screen */

/* common */
/* コピペ用コード */
.font-size-dummy { /*12px / 16px = 0.75*/
  font-size: .75rem;   /* 12px */
  font-size: .8125rem; /* 13px */
  font-size: .875rem;  /* 14px */
  font-size: 1rem;     /* 16px */
  font-size: 1.25rem;  /* 20px */
  font-size: 1.75rem;  /* 28px */
}
/* 使用カラーコード
98774B (茶) */
/* FC6582 (蛍光ピンク)*/
/* DDDDA9 (緑) */

body {
  margin: 0;
  color: #000;
  background: #FFFAF3;
  font-family: "游ゴシック体", "Yu Gothic", "YuGothic","YuGothicM", "Helvetica",'Roboto',"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Arial", "メイリオ", "Meiryo", sans-serif;
  letter-spacing: 0.05em;
  font-feature-settings: "palt";
}

main {
  overflow: hidden;
}

h1,
h2,
h3,
h4,
p,
ul {
  margin: 0;
  padding: 0;
}

p {
  font-size: 1rem;
  line-height: 1.6;
}

 a {  /*ボタン*/
  text-decoration: none;
  display: block;
  margin: 0 auto;
  margin-top: 10%;
  cursor: pointer;
  width: 250px;
  border-radius: 40px;
  padding: 16px 0;
  font-feature-settings: "palt" 0;
  text-align: center;
  box-shadow: 2px 2px 2px #a0a0a0;
  transition: 0.3s;
  background: #FC6582;
  animation: dokidoki 5s ease-in-out 0s infinite;
}

a:hover {
  opacity: .7;
}

@keyframes dokidoki {
  0% {
    transform: scale(1);
  }
  20% {
    transform: scale(1.05);
  }
  40% {
    transform: scale(1);
  }
  60% {
    transform: scale(1.05);
  }
  80% {
    transform: scale(1);
  }
  100% {
    transform: scale(1);
  }
}

button {
  color: #FFFAF3;
  background: inherit;
  border: none;
  font-size: 1.125rem;
  letter-spacing: 0.06rem;
  cursor: pointer;
}

button span {
  border-bottom: 2px dotted #FEF5BF;
  font-size: 1rem;
}
/* main */

.main-visual {
  width: 100%;
  height: auto;
}

.main-visual img {
  /* max-width: 520px; */
  width: 100%;
  object-fit: contain;
  display: block;
  margin-top: 8px;
}

section {
  margin-top: 10%;
  /* padding: 40px 0; */
}

.service-container,
#message {
  padding-left: 2%;
  padding-right: 2%;
}

.service-container { /*フルサポートプラン*/
  display: flex;
  flex-direction: column;
  padding: 70px 2%;
  height: 100%;
  background: pink url(../LPimg/23242271_1.jpg) no-repeat center/ 100% 100%;
}

img.service-img{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  margin-left:-10px;
}

/*サービス内容*/
.plan-container,
#plan {
  padding-left: 5%;
  padding-right: 5%;
}
.plan-container{
  display: flex;
  flex-direction: column;
  padding: 10px 2%;
  height: 100%;
  background: #FFF;
}

.serviceplan {
  position: relative;
  padding: 20px 0px;
  margin-top: 0px;
  background: #fff;
}

.serviceplan0 {
  position: relative;
  padding: 20px 40px;
  margin-top: 10px;
  background: #FFFAF3;
  box-shadow: 0 4px 4px -4px #E6DDCF, 0 -4px 4px -4px #E6DDCF;

}

.serviceplan01 h3 span {
  border-bottom: 6px solid #FEE0CF;
  border-radius: 4px;
}

.serviceplan01 h4 {
  margin-top:10px 10px;
  padding: 0.5em;
  width: 300px;
  background: ddddae;
  box-shadow: 0 0 4px rgba(0, 0, 0, 0.23);
}

.serviceplan h3,
.serviceplan h4,
.serviceplan p {
  margin-top: 12px;
  color: #000;
  padding: 0 24px;
}




div.plan-img{
display: block;
  /*align-items: center;*/
  justify-content: center;
}


/* 第4期生募集*/
.rec-container{
  justify-content: center;
  padding: 10px 40px;
  width: 100%;
  height: auto;
}

rec-container,
#rec {
  padding: 2%;
  background: #fff;
  width: 100%;
  height: auto;
}

.rec-text {
  position: relative;
  padding: 20px 40px;
  margin-top: 10px;
  background: #fff;

}

.rec-container img {
  width: auto;
  height: 500px;
}


/* 過去の受講生の声（追加分）*/
voice-container,
#voice {
  padding-left: 2%;
  padding-right: 2%;
}

.voice-container{
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding: 10px 40px;
}

.voice-text {
  position: relative;
  padding: 20px 40px;
  margin-top: 10px;
  background: #fff;
}

h2 {
  text-align: center;
  font-size: 1.5rem;
  font-weight: bold;
  color: #ec9d9d;
  padding: 0.7rem 0;
  margin: 0 auto;
  position: relative;
}

h2::before {
  content: '';
  background: #98774B;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  position: absolute;
  bottom: 0;
  right: 26px;
  box-shadow: -16px 1px 0 -1px #ec9d9d;
}

h2::after{
  content: '';
  background: #98774B;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  position: absolute;
  bottom: 0px;
  right: 6px;
  box-shadow: 20px -2px 0 1px #98774B;
}


.service-number {
  position: relative;
  padding: 64px 0;
  margin-top: 40px;
  background: #fff;
  box-shadow: 0 4px 4px -4px #E6DDCF, 0 -4px 4px -4px #E6DDCF;
}

.service-number + .service-number {
  margin-top: 100px;
}

.number {
  position: absolute;
  top: -50px;
  left: 16px;
  font-size: 4.375rem;
  font-weight: bold;
  color: #000;
}

.service-number h3,
.service-number h4,
.service-number p {
  margin-top: 12px;
  color: #000;
  padding: 0 24px;
}

.service-number h3:first-child {
  margin-top: 0;
}

.service-number h3 {
  font-size: 1.375rem;
  position: relative;
}

.service-number h3 span {
  border-bottom: 6px solid #FEE0CF;
  border-radius: 4px;
}

.service-number img {
  width: 100%;
  object-fit: contain;
}

div.movie-img service-pc-img{
  display: flex;
  justify-content: center;
}

div.service-img00{
  vertical-align:top;
  justify-content: center;
}

img.movie-img-contents {
  width: 100%;
  margin-top: 0;
  object-fit: scale-down;
  height: 600px;
}

img.plan-img-contents0 {
  width: 100%;
  margin-top: 0;
  object-fit: scale-down;
  /*
  height: 300px;*/
  justify-content: center;
}

img.plan-img-contents1 {
  width: 100%;
  margin-top: 0;
  object-fit: scale-down;
  /*
  height: 700px;
  */
  justify-content: center;
}


.content01 h4:nth-child(1) {
  margin-top: 0;
}

.content01 h4 {
  line-height: 2.5;
}

.content01 p {
  margin-top: 0;
}

.contents-btn {
  margin: 32px 0;
  text-align: center;
}
.contents-btn p {  /*動画購入ボタン */
  font-size: .875rem;
  font-weight: bold;
  line-height: 2;
  display: inline-block;
  position: relative;
}

.contents-btn p::before {
  content: '';
  background: #000;
  width: 28px;
  height: 1px;
  display: inline-block;
  transform: rotate(70deg);
  position: absolute;
  bottom: 22px;
  left: -4px;
}

.contents-btn p::after {
  content: '';
  background: #000;
  width: 28px;
  height: 1px;
  display: inline-block;
  transform: rotate(-70deg);
  position: absolute;
  bottom: 22px;
  right: -4px;
}

.contents-btn p span {
  border-bottom: 3px dotted #DDDDA9;
  padding-bottom: 3px;
}


.contents-btn a {
  background: #DDDDA9;
  border: 1px solid #333;
  padding: 16px 0;
  border-radius: 32px;
  margin: 0 auto;
}

.contents-btn a:hover {
  background: #f9ecd8;
}

.contents-btn  a button {
  color: #000;
  font-size: 1rem;
}

.service-text {
  margin-top: 8px;
}

.service-text p {
  overflow-wrap: break-word;
}

.img04 {
  height: 340px;
  position: relative;
}

img.pamphlet {
  width: 60%;
  height: 290px;
  position: absolute;
  right: 0px;
  top: 20px;
  z-index: 1;
}

img.example {
  display: inline-block;
  width: 60%;
  height: 250px;
  filter: blur(2px);
  transform: rotate(-20deg);
}

p.notice {
  font-size: .75rem;
}
.menu-text{
  text-align: center;
  margin-top: 10px;
}


#member {
  background: #fff;
  display: flex;
  flex-direction: column;
}

#member h2::before {
  background: #ec9d9d;
  box-shadow: -16px 1px 0 -1px #98774B;
}

.member-container {
  display: flex;
  justify-content: center;
  flex-direction: column;
  padding-left: 40px;
  padding-right: 40px;
}

.member-container h3 {
  line-height: 2;
}

.member {
  text-align: center;
  margin-top: 16px;
}

img.leader {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
  filter: brightness(140%) contrast(110%);
}

img.subleader {
  background: #ddd;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
}

#member h3 {
  margin-top: 8px;
}

#message {
  background: #fff;
  color: #000;
  padding-top: 32px;
  padding-bottom: 32px;
  display: flex;
  flex-direction: column;
  font-family: 'Hannotate SC','Chalkboard','','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3',sans-serif;
}

img.message-img {
  width: 100%;
  filter: brightness(120%) contrast(110%);
  border-radius: 24px;
}

img.message-img2 {
  display: none;
}

.message-title {
  display: flex;
  flex-direction: column;
}

#message  {
  color: #A5C5CF;
  margin-top: 16px;
}

#message h2::before {
  background: #98774B;
  box-shadow: -16px 1px 0 -1px #98774B;
}

#message h2::after {
  background: #A5C5CF;
  box-shadow: 20px -2px 0 1px #98774B;
}

#message p {
  color: #000;
  margin-top: 32px;
  padding: 0 24px;
  line-height: 1.6;
  font-feature-settings: "palt";
}

#message span {
  font-weight: bold;
  color: #333;
}

#message .name {
  text-align: center;
  font-size: 1rem;
  margin-top: 16px;
  display: block;
  position: relative;
}

#message .name::before {
  content: '';
  display: inline-block;
  width: 3rem;
  height: 3px;
  background: #A5C5CF;
  border-radius: 2px;
  position: absolute;
  left: 50%;
  bottom: -6px;
  transform: translateX(-50%);
}


#price {
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: center;
  position: relative;
  background: #fff;
  z-index: -3;
}

img.recruitment {
  width: 100%;
  margin-top: 40px;
  display: block;
}

.price-container {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.coaching-price {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding: 5% 0;
  box-sizing: border-box;
  width: 90%;
  box-shadow: 0 0 2px 2px #E6DDCF;
  background: #fff;
  margin: 0 auto;
  border-top: 0.5rem dashed #E6DDCF;
  border-bottom: 0.5rem dashed #E6DDCF;
  z-index: -2;
}


#price .coaching-price h2::before {
  all: unset;
  content: '';
  display: inline-block;
  width: 72px;
  height: 72px;
  background: #fff8b7;
  border-radius: 50%;
  position: absolute;
  top: -12px;
  left: -10px;
  z-index: -1;
}

#price  .coaching-price h2::after {
  all: unset;
}

#price .coaching-price h2 {
  color: #FC6582;
  font-size: 1.375rem;
  font-weight: bold;
  padding: 1rem 0;
  letter-spacing: 0.2em;
}

#price ul {
  list-style: none;
  margin: 0 auto;
  text-align: left;
}

ul li {
  line-height: 2;
  font-weight: bold;
  font-size: 1rem;

}

li i {
  color: #333;
  font-size: 1.125rem;
}


li i::after {
  content: " ";
}

.coaching-price h3 {
  color: #000;
  padding-bottom: 0;
  line-height: 2;
  font-size: 1.25rem;
  border-bottom: 5px double #E6DDCF;
  width: 80%;
  margin: 0 auto;
  font-weight: normal;
  text-align: right;
}


.coaching-price h3 span {
  font-size: 1.375rem;
  padding-right: 0.5rem;
}


.movie-img-price {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: .5rem;
  padding: 2% 5%;
  box-sizing: border-box;
  width: 90%;
  box-sizing: border-box;
  box-shadow: 0 0 2px 2px #E6DDCF;
  background: #fff;
  margin: 0 auto;
  text-align: center;
  letter-spacing: 0.1rem;
  border-top: 0.5rem dashed #A5C5CF;
  border-bottom: 0.5rem dashed #A5C5CF;
}

.movie-price h3 {
  font-weight: normal;
  padding-top: 8px;
  font-size: 1.5rem;
}

.movie-price > p {
  margin-top: 0;
  font-size: 1rem;
  font-weight: normal;
  line-height: 2;
  text-align: right;

}

a.admission {
  width: 290px;
  padding: 20px 0;
  border-radius: 8px;
  background: #E6DDCF;
}

a.admission:hover {
  background: #DDDDA9;
}

a.admission button {
  color: #000;
  font-weight: normal;
}

a.admission button span {
  font-size: 1.125rem;
  border-bottom: 2px dotted #444;
  padding-bottom: 4px;
}

#q_a {
  padding-left: 5%;
  padding-right: 5%;
  display: flex;
  flex-direction: column;
}

#q_a h2 {
  color: #ec9d9d;
}


#q_a h2::before,
#q_a h2::after {
  background: #ec9d9d;
}

dl {
  background: #fff;
  border-radius: 16px;
  padding: 5%;
}

dd::before {
  content: "Q. ";
}

dd {
  margin: 0;
  font-size: 18px;
  padding: 1rem 0;
  font-weight: bold;
}

dt::before {
  content: "A. ";
}

dt {
  font-size: 14px;
  line-height: 1.6;
}

/* footer */
footer {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: #fff;
  text-align: center;
  padding: 30px 0;
  margin-top: 5%;
  border-top: 2px solid #98774B;
}

.footer-wrapper {
  /* width: 28%;
  text-align: left;
  margin: 0 auto; */
  display: flex;
  flex-direction: column;
  align-items: center;
}


.sns {
  gap: 24px;
  display: flex;
}

.sns a {
  all: initial;
  cursor: pointer;
  text-decoration: none;
}

.sns a:hover {
  opacity: .7;
}

i.bi-instagram {
  font-size: 1.75rem;
  color: #4C64D3;
  cursor: pointer;
}

.terms-of-service {
  all: initial;
  cursor: pointer;

}

.box1{
  padding: 20px 20px;
  width: 200px;
}

.box2{
  padding: 20px 20px;
  width: 200px;
}

.footer-flex{
 display: flex;  
 margin-top: 5%;
}

.footer p {
  color: #000;
  font-size: .75rem;
}
/* 特定商取引法に基づく表記 */

.toku-container { 
  height:100%;
  justify-content: center;
}

#tokushoho {
  margin: 5% auto;
  width: fit-content;
  padding:5%;
  justify-content: center;
}

.toku-container h1 {
  text-align: center;
  font-size: 1.75rem;
}

.toku-container div {
  margin-top: 3%;
}

.toku-container p {
  all: initial;
  line-height: 1.8;
}

.toku-container h3 {
  all: initial;
  line-height: 1.8;

}

/* 利用規約ページ */

#terms-of-service {
  padding: 0 2%;
  margin-bottom: 15%;
}

#terms-of-service h1 {
  margin-top: 15%;
  text-align: center;
  font-size: 1.75rem;
}

#terms-of-service .introduction {
  margin-top: 10%;
}

#terms-of-service div {
  margin-top: 10%;
}

#terms-of-service p {
  line-height: 1.8;
}

#terms-of-service h2 {
  all: initial;
  /* margin-top: 100px; */
  line-height: 2;
}

#terms-of-service h2::before {
  all: initial;
}

#terms-of-service h2::after {
  all: initial;
}

#terms-of-service ol {
  margin: 0;
  padding: 0;
  list-style-position: inside;
  padding-left: 1rem;
	text-indent: -1rem;
}

ol.parentheses {
  list-style-type: none;
  list-style-position: inside;
  padding-left: 1rem;
	text-indent: -1rem;
}

ol.parentheses li {
  counter-increment: cnt;
  padding-left: 1rem;
	text-indent: -1rem;
  line-height: 1.8;
}

ol.parentheses li::before {
  content: "(" counter(cnt) ") ";
}

#terms-of-service .postscript {
  margin-top: 10%;
}


/* pc screen*/
@media screen and (min-width: 768px){

  .main-visual {
    max-width: 90%;
    margin: 0 auto;
  }

  .main-visual img {
    max-height: 500px;
  }

  section {
    max-width: 100%;
  }

  a {
    width: 420px;
    padding: 24px 0;
    animation: initial;
  }

  button {
    font-size: 1.25rem;
  }

  h2 {
    font-size: 2rem;
  }

  .service-number h3 {
    font-size: 1.5rem;
    letter-spacing: 0.08rem;
    line-height: 2;
  }

  .service-container {
    padding: 70px 5%;
  }

  .service01 {
    padding-left: 8%;
    padding-right: 8%;
  }

  .number {
    font-size: 5.25rem;
    left: 24px;
  }

  .service01 > p {
    line-height: 1.8;
  }

  .service-flex {
    display: flex;
    margin-top: 32px;
  }

  .service-flex .service-pc-img {
    width: 50%;
  }

  img.movie-contents {
    margin-top: 0;
    width: 100%;
    object-fit: contain;
  }

  img.plan-contents {
    margin-top: 0;
    width: 100%;
    object-fit: contain;
  }

  .content01 {
    width: 50%;
    padding: 0 20px;
    box-sizing: border-box;
  }

  .content01 h4 {
    margin-top: 0;
  }

  .content01 p {
  padding-left: 32px;
  }
  .content02 {
    width: 50%;
    padding: 0 20px;
    box-sizing: border-box;
  }

  .content02 h4{
      margin-top: 0;
      width: fit-content;
      background: #a8d3ff;
  }

  .content03 {
    width: 50%;
    padding: 0 20px;
    box-sizing: border-box;
  }

  .content03 h4{
    margin-top: 0;
    width: fit-content;
      background: #a8d3ff;
  }
  
  .contents-btn {
    margin-top: 40px;
  }

  .contents-btn p {
    font-size: 1rem;
  }

  .contents-btn a {
    padding: 24px 0;
    border-radius: 40px;
  }

  .contents-btn a button {
    font-size: 1.125rem;
  }

  .service-text {
    padding: 0 2%;
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: 0;
  }

  .service-text p {
    padding-left: 2rem;
    font-size: 1.125rem;
    line-height: 1.7;
  }

  #member {
    width: 90%;
    margin: 10% auto 0 auto;
  }

  #member .member-container {
    display: flex;
    flex-direction: row;
    gap: 2%;
    margin-top: 2%;
  }

  #member .member {
    width: 50%;
    box-sizing: border-box;
    padding: 0 4%;
  }

  .member img {
    width: 220px;
    height: 220px;
  }

  .member p {
    line-height: 1.8;
  }


  #message {
    display: flex;
    flex-direction: row;
  }

  div.message-img {
    width: 50%;
    display: flex;
    flex-direction: column;
    align-self: center;
  }

  img.message-img {
    display: none;
  }

  img.message-img2 {
    display: block;
    width: 100%;
    filter: brightness(150%);
    border-radius: 16px;
    height: 800px;
    object-fit: scale-down;
  }

  .message-title {
    width: 50%;
  }

  img.recruitment {
    width: 90%;
    height: 440px;
    object-fit: contain;
    margin: 0 auto;
  }

  hr{
    border-top: 3px dotted #98774B;
    border-right: none;
    border-bottom: none;
    border-left: none;
  }

  #price {
    width: 100%;
    margin-top: 10%;
  }

  #price .price-container {
    display: flex;
    flex-direction: row;
    width: 90%;
    margin: 0 auto;
  }


  #price .price-container h2 {
    font-size: 1.75rem;
  }

  #price .price-container li {
    font-size: 1.25rem;
  }

  #price .price-container i {
    font-size: 1.25rem;
  }

  .coaching-price {
    /* display: flex; */
    width: 60%;
  }

  #price .movie-price {
    width: 40%;
    gap: 1.25rem;
  }

  #price .movie-price h3 {
    font-size: 1.75rem;
    position: relative;
  }

  #price .movie-price p {
    font-size: 1.25rem;
  }

  a.admission {
    width: 500px;
    padding: 30px 0;
  }

  a.admission button {
    font-size: 1.25rem;
  }

  a.admission i {

  }

  dl {
    display: flex;
    justify-content:center;
    gap: 32px;
  }

  dl div {
    width: 50%;
    display: flex;
    flex-direction: column;
    text-align: center;
  }

  dd {
    font-size: 1.25rem;
  }

  dt {
    font-size: 1rem;
    line-height: 1.8;
  }

  footer .sns {
    gap: 56px;
  }

  /* 利用規約ページ */
  #terms-of-service {
    padding: 0 8%;
    margin-bottom: 7%;
  }

  #terms-of-service h1 {
    font-size: 2rem;
    margin-top: 7%;
  }

  #terms-of-service .introduction {
    margin-top: 5%;
  }

  #terms-of-service div {
    margin-top: 7%;
  }

  #terms-of-service p {
    line-height: 1.8;
  }

  #terms-of-service .postscript {
    margin-top: 10%;
  }
}