/*
Theme Name: miyakonail
Theme URL: https://miyako-nail.com/
Description: ネイルスクールMIYAKOの公式サイト用に制作されたWordPressテーマ。カリキュラム紹介、Studentサロン、卒業後サポート情報などを発信。
Author: nailschoolmiyako
Version: 1.0.0
Tags: responsive, clean, beauty, school, custom-template
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/
/* この下に通常のcssを書いていく */


@charset "utf-8";
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html, body {
  margin: 0;
  padding: 0;
  height: 100%;
}
html {
  font-family: "Hiragino Kaku Gothic ProN", "Yu Gothic", "Meiryo", sans-serif;
  letter-spacing: 0.06em;
		line-height: 1.6;
  text-rendering: optimizeLegibility;
  font-feature-settings: "palt"1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-kerning: normal;
  font-kerning: normal;
  -webkit-text-size-adjust: none;
}
body {
  margin: 0;
  padding: 0;
  background-color: #fbf6f4;
  position: relative;
  color: rgba(0, 0, 0, .8);

}


body::after {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99999999;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.8s ease;
  -webkit-transition: opacity 0.8s ease;
}
body.fadeout::after {
  opacity: 1;
}

body.about-page {
  background-color: #ffffff;
}

ul li::marker {
  content: none;
}
li { list-style: none;}

a {
  text-decoration: none;
  transition: opacity 0.4s ease;
}
a:hover {
  opacity: 0.7;
}
a, input, select, textarea, button, *:before, *:after {
  transition: opacity 0.4s ease;
}
a:focus, input:focus, select:focus, textarea:focus, button:focus {
  outline: none;
}
img {
  width: 100%;
  vertical-align: bottom;
  image-rendering: pixelated;
}
.pc_off {
  display: none;
}
.sp_off {
  display: block;
}
@media screen and (max-width: 819px) {
  .sp_off {
    display: none !important;
  }
  .pc_off {
    display: block;
  }
}
.mincho {
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;}
h2 {	font-weight: 600;
  font-size: 35px;
}
h3 {
  font-size: 2rem;
}

p{ line-height: 1.6rem;
font-size: 0.95rem;
font-weight: 550; /* フォントを太くする */
	letter-spacing: 2px;}

.en, .reason { font-size: 1.4rem; color: #b47928;font-family:"pritzious"; }

.small{font-size:12px; line-height: 120%;}

@media screen and (max-width: 819px) {
  h2 {
    font-size: 1.6rem;
  }
  h3 {
    font-size: 1.3rem;
  }
	p{ line-height: 1.4rem;
	 font-weight: 550; /* フォントを太くする */
  -webkit-font-smoothing: antialiased;
font-size: 0.87rem;	letter-spacing: 2px;}
	
	.en { font-size: 0.9rem; color: #b47928; }
	
	
	.reason { font-size:1.2rem; color: #b47928; 
	font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;}
	
	.small{font-size:10px; line-height: 90%;}
}

img {
    max-width: 100% !important;
    height: auto;
}

.center{ text-align: center;}



a{text-decoration: none;
    color: inherit;
    transition: all 0.3s ease;}
/* ==========================================================================
	メニュー
========================================================================== */
header {
	position: fixed;
	z-index: 1;
  display: flex;
 align-items: center;
  justify-content: space-between;
	  width: 100%;
  margin: 0 auto;
  padding: 2% 0;
  background: #fff;
	
}
header img {width: 100%;
	vertical-align: top;
    border: 0;
	padding-left: 20px;
}

header nav {  right: 0;
position: absolute;
}

header nav ul {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
}
header nav ul li {font-size: 0.87rem;
  position: relative;
  margin: 0 20px;
}
header nav ul li a {
  text-decoration: none;
  color: #333;
  font-weight: bold;
  padding: 10px;
  display: block;
	
}
/* アコーディオン部分 */
header nav ul li:hover div {
  max-height: 200px;
  opacity: 1;
  padding: 10px 0;
}
header nav ul li div {
  position: absolute;
  top: 100%;
  left: 0;
  background: #f8f8f8;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  max-height: 0;
  transition: all 0.3s ease;
  opacity: 0;
  z-index: 999;
  width: 200px;
}
header nav ul li div a {
  padding: 10px 15px;
  font-weight: normal;
  color: #555;
  border-bottom: 1px solid #eee;
}
header nav ul li div a:hover {
  background: #eee;
  color: #000;
}

header nav ul li a:hover,
header nav ul li a:focus {
  color: #e26c63;
}

.logo {
  width: 200px;
}

@media screen and (min-width: 820px) {
#nav {display: none;}
}

@media screen and (max-width: 819px) {
  nav {
    display: none;
  }
	header{height: 60px;}



.btn_menu {
    width: 30px;
    height: 30px;
    position: absolute;
    top: 16px;
    right: 16px;
    z-index: 999;
  }
  .btn_menu::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    background: url(image/btn_menu.webp) no-repeat;
    background-position: center;
    background-size: contain;
  }
  .btn_menu.active::after {
    background-image: url(image/btn_close.webp);
    filter: invert(1);
  }
  #nav {
    position: fixed;
    top: 0;
    left: auto;
    right: -30px;
    width: 74%;
    height: 100vh;
    background: rgba(255, 75, 122);
    margin: 0;
    padding-top: 70px;
	  font-weight: bold;
    transform: translateX(100%);
    transition: all 0.3s ease;
  }
  #nav.active {
    transform: translateX(0);
  }
  ul.navi {
    padding-left: 14px;
    box-sizing: border-box;
  }
  ul.navi li {
    width: 100%;
    margin: 0;
    text-align: center;
  }
  ul.navi li a {
    font-size: 14px;
    display: block;
    padding: 10px 0;
    color: #fff;
    text-align: left;
  }
 #nav img{ width:80%;
	}
}



/* ==========================================================================
	footer
========================================================================== */
#footer {
  position: relative;
  padding: 5px 0 0;
	    width: 100%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 40px 10%; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	    position: relative;
    padding-bottom: 15%;
    background: url(image/footerbg_pc.webp) bottom center no-repeat;
    background-size: 100% auto;
}

#footer p{	line-height: 1.4rem;
  -webkit-font-smoothing: antialiased;
font-size: 0.8rem;	letter-spacing: 2px;}

#footer .pagetop:hover {
  transform: translate3d(0, -10px, 0);
  filter: alpha(opacity=100);
  -moz-opacity: 1;
  opacity: 1;
  -webkit-transition: transform 0.2s ease;
  -moz-transition: transform 0.2s ease;
  -o-transition: transform 0.2s ease;
  transition: transform 0.2s ease;
}
#footer h2 {
  width: 234px;
  margin: 0 auto
}
#footer .sns_link {
  width: 40px;
}
#footer .logo {
  width: 60%;
}

#footer .en{ font-size:0.7rem;}

@media screen and (max-width: 819px) {
	#footer {
    background: url(image/footerbg.webp) bottom center no-repeat;
    background-size: 100% auto;
		padding-bottom: 55%;
}
	
	
  #footer:after, #footer:before {
    display: none;
  }
  #footer .footer_inr {

  }
}
/* ==========================================================================
	about
========================================================================== */
.fadeIn {
  transition: 1.5s;
  transform: translate3d(0, 30px, 0);
  opacity: 0;
}
.fadeIn.animated {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

/* ==========================================================================
	section
========================================================================== */

section {
  max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
  width: 90%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 10% 10%; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
}

.top-hero{
	  max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
  width: 90%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 10% 5% 0; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align:center;
}

.topblog{
  width: 98%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 10% 0 0; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align:center;
}

.pagekotei{  width: 98%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 5% 0 0; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align:left;}


.blog{  width: 98%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 5% 0 0; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align:left;}

.blog h1,h2,h3,h4,h5{
font-family: 'ヒラギノ明朝 Pro W3', 'Hiragino Mincho Pro', 'ＭＳ Ｐ明朝', 'MS PMincho', serif;
	color:#bc2a3e;
}
.blog p{ margin-bottom:3%;}
@media screen and (max-width: 819px) {
.blog p{ margin-bottom:5%;}
	
}

.top-why{
	  max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
  width: 90%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 0 0 5%; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align:center;
}

.pagebox {
   width: 100%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 0; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
}

#faq {
   width: 80%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 0 10%; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
}

.section{
	padding: 10% 10px; /* 上下に余白、左右少しスペース */
	
}
.contents_block { position: relative;
  padding: 5% 0;
	background-image: url("image/message-bg_pc.webp");
	background-position: top;
	background-repeat: no-repeat;
	background-size: 100%;
	text-align: center;
}

.contents_rose {
  position: relative;
  background-image: url("image/support-bg.webp");
  background-position: center center; /* ←ここが重要 */
  background-repeat: no-repeat;
}
@media screen and (max-width: 819px) {
section {
  max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
		width: 96%; }
	
	.contents_block {
		padding: 10% 0;
	}
	.contents_block { 
	background-image: url("image/message-bg.webp");
}
	.top-hero{

  padding-right:0; 
		padding-left:0; 
		padding-top:5%;
}
	
}

/* ==========================================================================
	スライドショー
========================================================================== */


.main_visual {
  position: relative;
  width: 100%;
  aspect-ratio: 16 /8; /* ここで縦横比を設定 */
  overflow: hidden;
}
.catch {
  text-align: center;
 }

 h1, .h1-sub  {
  display: block;
font-size: 40px;
    font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
    text-align: center;
    line-height: 1.6;
	 margin-bottom: 1%;
	     -webkit-text-size-adjust: 100%;
	 font-weight: 500;
}
.catch h2{ font-size: 35px;
  margin-bottom: 2%;}

.slideshowoff {
  position: absolute;
  width: 100%;
  height: 100%;
	margin-top: 60px;
}

.slideshow {
  position: absolute;
  width: 100%;
  height: 100%;
	margin-top: 60px;
}

.slideshow div {
  position: absolute;
  width: 100%;
  opacity: 0;
  animation: fade 9s infinite;
}

.slideshow div:nth-child(1) { animation-delay: 0s; }
.slideshow div:nth-child(2) { animation-delay: 3s; }
.slideshow div:nth-child(3) { animation-delay: 6s; }

.slideshow img {
width: 100%;
  height: 100%;
  object-fit: contain;
}

@keyframes fade {
  0% { opacity: 0; }
  8% { opacity: 1; }
  30% { opacity: 1; }
  38% { opacity: 0; }
  100% { opacity: 0; }
}

@media screen and (max-width: 819px) {
	.main_visual {
  position: relative;
  width: 100%;
  height: 550px; /* ここはお好みで */
  overflow: hidden;
padding-top:60px;}
	
	.slideshow, .slideshowoff {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
	
 h1, .h1-sub  {
  line-height:120%;
font-size: 6.8vw;
margin-bottom:3%;
}	

	.catch h2{         font-size: 5.61vw;
	margin-bottom:1%;}
}

/* ==========================================================================
	横3つ
========================================================================== */

.container {margin-top: 3%; 
  display: flex;
  justify-content: space-between; /* 横並びでスペースを均等に */
  gap: 20px; /* 各アイテム間に隙間を追加 */
}

.item {
  flex: 1;
  display: flex;
  flex-direction: column;
	padding-bottom: 2%;
}
.item p{margin-bottom: 2%;}

.item .more02 {
  margin-top: auto;
}

.itemline{  background-color:#ffffff;
	border: #F8D4D6 1px solid;
 padding: 2%;}
.item img{margin-bottom:5%;}
.item h2 { font-size: 1rem; margin-bottom: 2%; text-align: center; color: #000;}
.item h3{font-size: 25px; line-height: 35px;  color:#b47928; font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif; font-weight:600; margin-bottom: 1%;}
.item h4{ font-size: 1.1rem; line-height: 140%; margin-bottom:2%;}
.item p{ text-align: left;font-size: 0.9rem;}


@media screen and (max-width: 819px) {
	.item h2 { font-size: 0.8rem; margin-bottom: 0.25%; text-align: center;}
.item h3{ font-size: 6vw; margin: 1.52%; 0; line-height: 7.5vw; font-weight:600;}
.item h4{ font-size: 1.1rem; line-height: 140%; margin-bottom:2%;}
.item p{ text-align: left; font-size: 0.85rem;}
	
	
  .container {margin-top: 5%; 
    flex-direction: column; /* SPでは縦並びに変更 */
    align-items: center; /* 中央揃え */
  }

  .item {
    width: 100%; /* アイテムをフル幅に */
	 
  }
	.itemline{ border-radius: 3%;
	 padding: 5% 5% 7% 5%;}
}

/* ==========================================================================
	ボタン
========================================================================== */


/* solid002 */
.button_solid002 a {
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 540px;
    padding: 1% 25px;
    color: #FFF;
    transition: 0.3s ease-in-out;
    font-weight: 600;
    background: #6bb6ff;
    filter: drop-shadow(0px 2px 4px #ccc);
    border-radius: 3px;
    border-radius: 50px;
	margin-top: 1%;
	margin-bottom: 1%;
}
.button_solid002 a:after {
    position: absolute;
    top: 50%;
    right: 20px;
    transition: 0.2s ease-in-out;
    content: "\f0da";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    transform: translateY(-50%);
}
.button_solid002 a:hover {
    transform: translateY(-2px);
    box-shadow: 0 15px 30px -5px rgb(0 0 0 / 15%), 0 0 5px rgb(0 0 0 / 10%);
}


@media screen and (max-width: 819px) {
.button_solid002 a {
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 340px;
    padding: 10px 25px;

		margin-top: 1%;
	margin-bottom: 3%;
}
	
}



/* BTNline */
.button_line a {
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 540px;
    padding: 1% 25px;
    color: #FFF;
    transition: 0.3s ease-in-out;
    font-weight: 600;
    background: #00c84b;
    filter: drop-shadow(0px 2px 4px #ccc);
    border-radius: 3px;
    border-radius: 50px;
	margin-top: 1%;
	margin-bottom: 1%;
}
.button_line a:after {
    position: absolute;
    top: 50%;
    right: 20px;
    transition: 0.2s ease-in-out;
    content: "\f0da";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    transform: translateY(-50%);
}
.button_line a:hover {
    transform: translateY(-2px);
    box-shadow: 0 15px 30px -5px rgb(0 0 0 / 15%), 0 0 5px rgb(0 0 0 / 10%);
}


@media screen and (max-width: 819px) {
.button_line a {
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 0 auto;
    max-width: 340px;
    padding: 10px 25px;

		margin-top: 1%;
	margin-bottom: 3%;
}
	
}
/* ==========================================================================
	コース
========================================================================== */

/* PC用スタイル */
@media screen and (min-width: 820px) {
  .studio {
    padding: 0 10%;
  }

  .studio_list li {
    width: 48%;
    margin-bottom: 2%;
  }
}

/* SP共通＆基本設定 */
ul.studio_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 5%;
  padding: 0;
  list-style: none;
}

ul.studio_list li {
  background: #f2dec1;
	  padding-bottom: 5%;
  text-align: left;
  box-sizing: border-box;
  overflow: hidden;
  border-radius: 6px;
}

ul.studio_list li a {
  display: block;
  color: inherit;
  text-decoration: none;

}

.corsetitle {
  font-size: 1.2rem;
	    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
    font-weight: 600;
    line-height: 1.4;
  padding: 2% 5%;
}
.detail {
  padding: 0 5%;
  font-size: 14px;
  line-height: 1.6;
}

.small {
  padding: 0 5%;
  font-size: 12px;
  color: #666;
}


/* モバイル対応 */
@media screen and (max-width: 819px) {
	  .studio {width:90%;
		  margin:0 auto;
    padding: 0 2%;
  }
	

  
  .corsetitle {
    font-size: 1rem;
  }

 
  .small {
    font-size: 11px;
  }

  .category a {
    font-size: 11px;
  }
	
	  .studio_list li {
    width: 48%;
  }

  .studio h3 {
    font-weight: 600;
    font-size: 14px;
  }

  .detail {
    font-size: 12px;
    padding-bottom: 15%;
  }
}


/* ==========================================================================
	生徒教室
========================================================================== */
.bg_gradation {
  
}


.effect_bg {
  position: absolute;
  bottom: 20px;
  left: 0;
  width: 100%;
  z-index: -1;
}

#effect .inner {
	max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
  width: 96%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 20px 10px; /* 上下に余白、左右少しスペース */
  box-sizing: border-box;
	text-align: left;
}

.effect_box {
  padding: 0px 70px;
  border-radius: 18px;
  box-sizing: border-box;
  margin-bottom: 10px;
}

.effect_block {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.effect_img {
  width: 39.8%;
}

ul.effect_list {
  width: 56%;
	text-align: left;
}

ul.effect_list li {
  position: relative;
  padding: 10px 0 0;
  margin-bottom: 30px;
}

ul.effect_list li h3 {color: #e26c63;
  position: relative;
  font-family: inherit;
  font-weight: 600;
  margin-bottom: 6px;
	 font-size: 1.6rem;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
}


ul.effect_list li p {
  position: relative;
}

.effect_circle {
  position: absolute;
  top: -20px;
  left: -75px;
  z-index: 0;
  width: 110px;
}

.eff_object {
  position: absolute;
  top: -3%;
  right: 4%;
  opacity: 0.8;
  width: 20%;
  z-index: -1;
}

.bgapple{ background-image: url(image/bg_apple.webp);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: top center;
  width: 100%;
	z-index: 1;
}
@media screen and (max-width: 819px) {
	
  .effect_block {
    padding-top: 20px;
  }
  .effect_box {
    padding: 0px;
    margin-bottom: 10px;
  }
  .effect_bg {
    bottom: 10px;
  }
  .effect_img {
    width: 90%;
    margin: 0 auto 20px;
  }
  ul.effect_list {
    width: 90%;
    margin: 0 auto;
  }
ul.effect_list li h3 {
	          font-size: 1.5rem;
        line-height: 120%;
  }
  .effect_circle {
    width: 100px;
    left: -11%;
    top: 0;
  }
	  .eff_object {
    width: 34%;
    right: 0;
		  z-index: 0;
  }
}

/* ==========================================================================
	faq
========================================================================== */
.animated1,
.animated2,
.animated3 {
  animation-duration: 1.5s;
  animation-fill-mode: both;
  opacity: 0;
}


.fadeInUp {
  animation-name: fadeinup;
  animation-duration: 1.5s;
}

@keyframes fadeinup {
  from {
    opacity: 0;
    transform: translatey(20px);
  }
  to {
    opacity: 1;
    transform: translatey(0);
  }
}

.inner {
  max-width: 820px;
  width: 90%;
  margin: 0 auto;
}

.faq_bg {
  position: absolute;
  bottom: 120px;
  left: 0;
  z-index: -1;
  width: 100%;
}

#faq h2{ font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif; color: #000000;}

#faq h3 {
	line-height: 1.4rem;
	 font-weight: 550; /* フォントを太くする */
  -webkit-font-smoothing: antialiased;
font-size: 0.87rem;	letter-spacing: 2px;
  margin-bottom: 30px;
}

#faq {width:100%;}

#faq .qa_block {
	margin-top: 5%;
	text-align: left;
	 font-weight: 550; /* フォントを太くする */
  -webkit-font-smoothing: antialiased;
letter-spacing: 2px;
line-height: 1.6rem;
font-size: 0.95rem;
}

.btn_area {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 40px;
  padding-bottom: 50px;
}

.btn_area div {
  margin: 0 5px;
}

#faq p {
  text-align: center;
}

dl.qa {
  margin-bottom: 15px;
  box-sizing: border-box;
  padding: 16px 30px;
  background: #f0e4d1;
  background: rgba(248, 228, 209, 0.7);
}

dl.qa dt {
  position: relative;
  cursor: pointer;
}

dl.qa dd {
  position: relative;
  display: none;
  margin-top: 16px;
	font-weight: bold;
	color: brown;
}

dl.qa dt::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  width: 12px;
  height: 12px;
  background: url("image/ico_plus.webp") no-repeat;
  background-position: center;
  background-size: contain;
}

dl.qa dt.active::after {
  transform: scale(1, -1);
  background-image: url("image/ico_minus.webp");
}

#faq .en {
    font-size: 2.5vw; 
  }

@media screen and (max-width: 819px) {
	#effect .inner {
		padding-top: 0;
}

	#faq {width:100%;}
	
  #faq .qa_block {font-size: 0.87rem;
    margin-bottom: 35px;
  }
  #faq h3 {
    margin-bottom: 18px;
  }
	  dl.qa dt {
    padding-right: 19px;
  }
  dl.qa {
    padding: 16px 20px;
  }
  dl.qa dt::after {
    right: -9px;
  }
  #faq p {
    font-size: 10.5px;
  }
	#faq .en {
    font-size: 6vw; 
  }
	  }




.container {
    position: relative;
    overflow: hidden;
}

/* cta_area
**************************************** */
.cta_area {
  position: relative;
  z-index: 1;
  width: 100vw;
  height: 580px;
  margin-left: calc(50% - 50vw);
  background-image: url(image/cta-bg.webp);
  background-position: bottom;
  background-size: cover;
}
.cta_area::before,
.cta_area::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 4px;
  background-image: url(image/border_yoko-wh.webp);
}
.cta_area::before {
  top: 14px;
}
.cta_area::after {
  bottom: 14px;
}
.cta_area .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.cta_area .inner::before {
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  width: min(35.7%, 380px);
  aspect-ratio: 380/519;
  background-image: url(image/ctaimg2.webp);
  background-position: center;
  background-size: cover;
}
.cta_area--txt {
  margin-left: -2vw;
}
.cta_area--list {
  gap: 24px;
}
.cta_area--cont {
  width: min(80%, 718px);
}

.lps_sec .cta_area {
  margin-bottom: 96px;
}
.lps_sec .cta_area:not(:first-child) {
  margin-top: 96px;
}
.lps_sec .cta_area:last-child {
  margin-bottom: -96px;
}

/* online-contact-btn */
.online-contact-btn a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 340px;
  height: 52px;
  font-size: 1.25rem;
  background: #8cabb8;
  color: #fff;
  border-radius: 100px;
  line-height: 0;
  vertical-align: middle;
  text-align: center;
  letter-spacing: 0.1em;
}
.online-contact-btn a:hover {
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .online-contact-btn {
    margin: auto;
  }

  /* cta_area */
  .cta_area {
    height: auto;
    background-image: url(image/cta-bg_sp.webp);
    background-position: top;
    background-repeat: no-repeat;
    background-size: 100%;
    aspect-ratio: 828/680;
  }
  .cta_area::before,
  .cta_area::after {
    display: none;
  }
  .cta_area .inner {
    display: block;
    width: 88%;
    height: auto;
  }
  .cta_area .inner::before {
    display: none;
  }
  .cta_area--cont {
    width: auto;
  }
  .cta_area--txt {
    width: 74.4%;
    padding-top: 13vw;
    margin-bottom: 5vw;
  }
  .cta_area--list {
    margin-top: 13vw;
  }
  .lps_sec .cta_area:not(:first-child) {
    margin-top: 48px;
  }
  .lps_sec .cta_area:last-child {
    margin-bottom: -48px;
  }
}


.mgn-btm24 {
    margin-bottom: 24px;
}



/* ==========================================================================
	ぽいんと３つ
========================================================================== */

.top-hero-crown-items {
  width: 100%;
  margin: 0 auto 8vw;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between;
	margin-top: 5%;
}
.top-hero-crown-items li {
  width: 32%;
  padding: 5.5vw 0 3.5vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
  font-weight: 600;
  text-align: center;
  line-height: 1.2;
  background: #fbf9f4;
  z-index: 0;
  position: relative;
}
.top-hero-crown-items li:nth-child(2) {
  -moz-transition-delay: 0.3s;
  -o-transition-delay: 0.3s;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
.top-hero-crown-items li:nth-child(3) {
  -moz-transition-delay: 0.6s;
  -o-transition-delay: 0.6s;
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
.top-hero-crown-items li:before {
  content: '';
  width: calc(100% - 8px);
  height: calc(100% - 8px);
  background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4gPHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGRlZnM+PGxpbmVhckdyYWRpZW50IGlkPSJncmFkIiBncmFkaWVudFVuaXRzPSJvYmplY3RCb3VuZGluZ0JveCIgeDE9IjAuNSIgeTE9IjAuMCIgeDI9IjAuNSIgeTI9IjEuMCI+PHN0b3Agb2Zmc2V0PSIwJSIgc3RvcC1jb2xvcj0iI2U2ZGZkMyIvPjxzdG9wIG9mZnNldD0iMjUlIiBzdG9wLWNvbG9yPSIjZmNmN2VhIi8+PHN0b3Agb2Zmc2V0PSI1MCUiIHN0b3AtY29sb3I9IiNlNmRmZDMiLz48c3RvcCBvZmZzZXQ9Ijc1JSIgc3RvcC1jb2xvcj0iI2ZjZjdlYSIvPjxzdG9wIG9mZnNldD0iMTAwJSIgc3RvcC1jb2xvcj0iI2U2ZGZkMyIvPjwvbGluZWFyR3JhZGllbnQ+PC9kZWZzPjxyZWN0IHg9IjAiIHk9IjAiIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9InVybCgjZ3JhZCkiIC8+PC9zdmc+IA==');
  background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #e6dfd3), color-stop(25%, #fcf7ea), color-stop(50%, #e6dfd3), color-stop(75%, #fcf7ea), color-stop(100%, #e6dfd3));
  background: -moz-linear-gradient(top, #e6dfd3, #fcf7ea, #e6dfd3, #fcf7ea, #e6dfd3);
  background: -webkit-linear-gradient(top, #e6dfd3, #fcf7ea, #e6dfd3, #fcf7ea, #e6dfd3);
  background: linear-gradient(to bottom, #e6dfd3, #fcf7ea, #e6dfd3, #fcf7ea, #e6dfd3);
  z-index: -1;
  position: absolute;
  top: 50%;
  left: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.top-hero-crown-items li:after {
  content: '';
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  background: #fbf9f4;
  z-index: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.top-hero-crown-items .small {
  margin-bottom: 1vw;
  font-size: 2.89vw;
  z-index: 1;
  position: relative;
  display: block;
}
.top-hero-crown-items .big {
  color: #e26c63;
  font-size: 4.61vw;
  z-index: 1;
  position: relative;
  display: block;
	font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
}
.top-hero-crown-item-content:before {
  content: '';
  width: 10vw;
  height: 7vw;
  background: url("image/icon-crown.webp") no-repeat center;
  background-size: 100%;
  z-index: 2;
  position: absolute;
  top: -3vw;
  left: 50%;
  -moz-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media screen and (min-width: 820px) {
	  .top-hero-crown-items {
    width: clamp(735px, 98%, 1200px);
    margin-bottom: 100px;
  }
	 .top-hero-crown-items {
    width: clamp(735px, 98%, 1200px);
    margin-bottom: 100px;
  }
  .top-hero-crown-items li {
    width: clamp(300px, 32%, 370px);
    padding: 35px 0 30px;
  }
  .top-hero-crown-items .small {
    margin-bottom: 4px;
    font-size: 20px;
  }
  .top-hero-crown-items .big {
    font-size: 34px;
  }
	  .top-hero-crown-item-content:before {
    width: 50px;
    height: 38px;
    background-size: 100%;
    top: -12px;
  }
	

}

/*NEWS
----------------------------------------------- */

/* 共通 */
.info-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.info-row .small {
  font-size: 12px;
  line-height: 120%;
  margin: 0;
}
.info-row .example {
  padding: 2px 12px;
  font-size: 12px;
  color: #ffffff;
  background-color: #d0942b;
  border: 1px solid #d0942b;
  border-radius: 20px;
  margin: 0;
  display: inline-block;
}

/* SP（縦並び） */
@media screen and (max-width: 819px) {
  .info-row {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* 横スライド
----------------------------------------------- */

.scroll-infinity__wrap {
  overflow: hidden;
	margin: 10% 0;
}

.scroll-infinity__list {
  display: flex;
  width: 130%; /* 100% x 2セット分 */
  animation: infinity-scroll-left 30s linear infinite;
}

.scroll-infinity__item {
  flex: 0 0 calc(100% / 8); /* 画像数で調整（8枚なら1/8） */
}

.scroll-infinity__item img {
  width:100%;
  display: block;
}

@keyframes infinity-scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}


@media screen and (max-width: 819px) {
	.scroll-infinity__list {
    animation: infinity-scroll-left 10s linear infinite;
}
	.scroll-infinity__wrap li img{height:90%;  }
.scroll-infinity__item {
  flex: 0 0 calc(100% / 4); /* 画像数で調整（8枚なら1/8） */
}

	
}
/* ==========================================================================
	問い合わせ
========================================================================== */
a {
  color: #272727;
  text-decoration: none;
  display: block;
  -moz-transition: all 0.3s cubic-bezier(0.76, 0, 0.24, 1);
  -o-transition: all 0.3s cubic-bezier(0.76, 0, 0.24, 1);
  -webkit-transition: all 0.3s cubic-bezier(0.76, 0, 0.24, 1);
  transition: all 0.3s cubic-bezier(0.76, 0, 0.24, 1);
}
a:hover {
  opacity: 0.8;
}
.clearfix:after {
  content: '';
  display: block;
  clear: both;
}

.center-link {
  text-align: center !important;
}
.center-link p {
  text-align: center !important;
}

.more01 {
  display: inline-block;
  width: 70vw;
  padding: 2vw 0;
  margin: auto;
  color: #f07f77;
  font-size: 3vw;
  font-weight: bold;
  text-align: center;
  border: 1px solid #f07f77;
  -moz-border-radius: 15vw;
  -webkit-border-radius: 15vw;
  border-radius: 15vw;
}

.more02 {
	display: inline-block;
  width: 50vw;
  padding: 2% 0;
  margin-left: auto;
	margin-right: auto;
	margin-top: auto;
  color: #f07f77;
  font-size: 3vw;
  font-weight: bold;
  text-align: center;
  border: 1px solid #f07f77;
  -moz-border-radius: 15vw;
  -webkit-border-radius: 15vw;
  border-radius: 15vw;
}

.more01 .title,
.more02 .title{
  padding-right: 5vw;
  margin: auto;
  background: url(image/arrow01@2x.webp) no-repeat center right;
  background-size: 2.5vw;
  display: table;
background-size: 10px;
	
  }



  .more01:hover {
    background: #FDF6F6;
    transition: .5s;
  }

@media screen and (min-width: 820px) {

  .more01 {
    width: 300px;
    padding: 20px 0 19px;
    font-size: 16px;
  }
	  .more02 {
    width: 60%;
    padding: 10px 0;
    font-size: 14px;
  }
	
  .more01 .title,
	  .more02 .title{
    padding-right: 20px;
  }
}

/* ==========================================================================
	うごき
========================================================================== */

.fade-bottom {
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.6s ease-out;
}

.fade-active {
  opacity: 1;
  transform: translateY(0);
}

/* ==========================================================================
	コース
========================================================================== */
.top-features-title {
  padding-top: 6.5vw;
  margin-bottom: 6vw;
  font-size: 6vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
  font-weight: 600;
  text-align: center;
  line-height: 1.4;
  z-index: 1;
  position: relative;
}
.top-features-title:after {
  content: 'Lesson';
  width: 100%;
  color: #e26c63;
  font-size: 15.2vw;
  font-family:"pritzious";
  font-weight: 300;
  line-height: 0;
  letter-spacing: 0.8vw;
  opacity: 0.2;
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
}

.top-features {
  padding-bottom: 4vw;
}
.top-features-image {
  margin-bottom: 8vw;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.top-features-image .image01, .top-features-image .image02 {
  width: 50%;
}
.top-features-image img {
  width: 100%;
}

	
.top-features-items {
  width: 90vw;
  margin: auto;
  counter-reset: number 0;
}
.top-features-item {
  margin-bottom: 15vw;
}


.top-features-item-badge {
  margin-bottom: 2.5vw;
  color: #f07f77;
  font-size: 5vw;
  font-family: "the-seasons";
  font-weight: 300;
  position: relative;
  display: table;
}
.top-features-item-title {
  margin-bottom: 2.5vw;
  color: #fff;
  font-size: 4.6vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
  font-weight: 600;
  line-height: 1.4;
}
.top-features-item-title .title {
  padding: 0.5vw 2vw 0;
  margin-bottom: 1.5vw;
  background: #f07f77;
  opacity: 1;
  position: relative;
  display: table;
}


.top-features-item-title .title.fade-active:nth-child(2):before {
  -moz-transition-delay: 0.3s;
  -o-transition-delay: 0.3s;
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
.top-features-item-title .title.fade-active:nth-child(3):before {
  -moz-transition-delay: 0.6s;
  -o-transition-delay: 0.6s;
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
.top-features-item-title .title.fade-active:before {
  width: 0;
}
.top-features-item-title .title:before {
  content: '';
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  background: #fff;
  position: absolute;
  top: -1px;
  right: -1px;
  -moz-transition: all 0.8s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  -o-transition: all 0.8s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  -webkit-transition: all 0.8s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  transition: all 0.8s cubic-bezier(0.05, 0.05, 0.31, 0.97);
}
.top-features-item-subtitle {
  margin-bottom: 2.5vw;
  color: #e26c63;
  font-size: 6.8vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
  font-weight: 600;
  line-height: 1.4;
  z-index: 1;
  position: relative;
}
.top-features-item-subtitle:after {
  content: ""counter(number, decimal-leading-zero);
  counter-increment: number 1;
  color: #fff;
  font-size: 30vw;
  font-family: "the-seasons";
  font-weight: 300;
  text-shadow: 1px 1px 0 #e26c63, -1px -1px 0 #e26c63, -1px 1px 0 #e26c63, 1px -1px 0 #e26c63, 0px 1px 0 #e26c63, -1px 0 #e26c63, -1px 0 0 #e26c63, 1px 0 0 #e26c63;
  opacity: 0.15;
  z-index: -1;
  position: absolute;
  top: 50%;
  right: 0;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.top-features-item-comment p {
  margin-bottom: 5vw;
  font-size: 3.8vw;
  text-align: justify;
  text-justify: inter-ideograph;
  font-feature-settings: "palt";
  line-height: 1.9;
  letter-spacing: .05em;
}
.top-features-item-comment span {
  color: #e26c63;
  font-weight: bold;
}
.top-features-item-image {
  width: 100%;
  margin: 4vw 0;
  overflow: hidden;
}
.top-features-item-image.fade-active img {
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -webkit-transform: scale(1);
  transform: scale(1);
}
.top-features-item-image img {
  width: 100%;
  -moz-transform: scale(1.05);
  -ms-transform: scale(1.05);
  -webkit-transform: scale(1.05);
  transform: scale(1.05);
  -moz-transition: all 1s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  -o-transition: all 1s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  -webkit-transition: all 1s cubic-bezier(0.05, 0.05, 0.31, 0.97);
  transition: all 1s cubic-bezier(0.05, 0.05, 0.31, 0.97);
}
.top-features-production {
  margin-top: 6vw;
}
.top-features-production-title {
  margin-bottom: 4vw;
  color: #e26c63;
  font-size: 4.4vw;
  font-weight: bold;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  align-items: center;
}
.top-features-production-title:before {
  content: '';
  height: 1px;
  margin-right: 2.5vw;
  background: #525252;
  flex: 1;
}
.top-features-production-title:after {
  content: '';
  height: 1px;
  margin-left: 2.5vw;
  background: #525252;
  flex: 1;
}
.top-features-production-items {
  width: 100%;
}
.top-features-production-items li { 
  width: 100%;
}
.top-features-production-items li:last-child .top-features-production-item-head {
  border: none;
}
.top-features-production-item-head {
  padding: 0 0 3.5vw;
  text-align: left;
  border-bottom: 1px dashed #ddd;
}
.top-features-production-item-title {
  margin-bottom: 0.5vw;
}

.studio_list img{ margin-bottom: 2%;}
.top-features-production-item-title .example {
  padding: 0.2vw 2vw;
  margin: 0 auto 2vw;
  color: #ffffff;
  font-size: 3.16vw;
  border: 1px solid #d0942b;
	background-color: #d0942b;
  -moz-border-radius: 5vw;
  -webkit-border-radius: 5vw;
  border-radius: 5vw;
  display: table;
}

@media screen and (max-width: 819px) {
  .top-features-production-item-title .example {
    display: inline-block;
    margin: 0 8px 0 0;
    font-size: 12px;
    vertical-align: middle;
  }

  .top-features-production-item-title .example + .example {
    margin-left: 8px;
  }
}

.top-features-production-item-title .course {
  font-size: 4.4vw;
  font-weight: bold;
  line-height: 1.4;
}
.top-features-production-item-price .price, .top-features-production-item-price-monthly .price {
  margin: 0 auto 4px;
  color: #f07f77;
  font-size: 3.8vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
  position: relative;
  display: table;
}
.top-features-production-item-price .price span, .top-features-production-item-price-monthly .price span {
  font-size: 10vw;
  font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
	
}
.top-features-production-item-price-monthly .price:before {
  content: '月額';
  font-size: 3.6vw;
  letter-spacing: 0.2vw;
  -ms-writing-mode: tb-rl;
  writing-mode: tb-rl;
  position: absolute;
  top: 0.6vw;
  left: -4.5vw;
}
.top-features-production-item-price-monthly .option {
  width: 35vw;
  padding: 1vw 0;
  margin: 0 auto 1vw;
  color: #fff;
  font-size: 3.6vw;
  font-weight: bold;
  background: #e26c63;
  -moz-border-radius: 5vw;
  -webkit-border-radius: 5vw;
  border-radius: 5vw;
  display: table;
}
.top-features-production-item-foot {
  margin: 2.5vw 0;
}
.top-features-production-item-foot p {
  font-size: 3.6vw;
  text-align: justify;
  text-justify: inter-ideograph;
  font-feature-settings: "palt";
  line-height: 1.8;
  letter-spacing: .05em;
  text-align: center;
}
.top-features-logo-items {
  width: 80%;
  margin: 6vw auto 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-justify-content: center;
  justify-content: center;
}
.top-features-logo-items li {
  width: auto;
  height: 8vw;
  margin: 0 2vw 2.5vw;
}
.top-features-logo-items img {
  width: auto;
  height: 100%;
}
.top-features-item-image.fade-active img {
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -webkit-transform: scale(1);
  transform: scale(1);
}

@media screen and (min-width: 820px) {
.top-features-title {
    width: 1200px;
	width: 80vw;
    font-size: 35px;
    padding: 40px 0;
    margin: 0 auto 50px;
    text-align: left;
}

.top-features-title:after {
    width: auto;
    font-size: 136px;
    letter-spacing: 8px;
    top: 0;
    right: -100px;
    left: auto;
}
	 .top-features-items {
    width: 1200px;
    width: 80vw;
  }
	
	  .top-features-item {
    margin-bottom: 80px;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
  }
	


	
	.top-features-item:last-child {
    margin: 0;
  }
  .top-features-item:nth-child(odd) .top-features-item-badge {
    right: clamp(-18px, -10%, -50px);
  }
  .top-features-item:nth-child(odd) .top-features-item-image {
    margin-right: -100px;
  }
  .top-features-item:nth-child(even) .top-features-item-badge {
    left: -50px;
  }
  .top-features-item:nth-child(even) .top-features-item-text {
    order: 1;
  }
  .top-features-item:nth-child(even) .top-features-item-image {
    margin-left: -100px;
    order: 0;
  }
		 .top-features-item-text {
    width: 560px;
    position: relative;
  }
	  .top-features-item-title {
    margin-bottom: 15px;
    font-size: 24px;
  }
  .top-features-item-title .title {
    padding: 3px 10px 2px;
    margin-bottom: 5px;
  }
	  .top-features-item-subtitle {
    margin-bottom: 30px;
    font-size: 35px;
  }
  .top-features-item-subtitle:after {
    display: none;
  }
	
	 .top-features-item-comment p {
    margin-bottom: 25px;
    font-size: 16px;
    line-height: 2;
  }
	
	
  .top-features-item-badge {
    margin-bottom: 0;
    font-size: 215px;
    opacity: 0.8;
    z-index: 1;
    position: absolute;
    top: 295px;
  }
  .top-features-item-badge:after {
    display: none;
  }
	  .top-features-item-image {
    width: clamp(405px, 50%, 700px);
    margin: 0;
  }
	
  .top-features-production {
    margin-top: 30px;
  }	
	
  .top-features-production-title {
    margin-bottom: 20px;
    font-size: 20px;
  }
  .top-features-production-title:before {
    margin-right: 20px;
  }
  .top-features-production-title:after {
    margin-left: 20px;
  }
	  .top-features-production-item-title .example {
    margin: 0 8px 0 0;
    font-size: 12px;
    text-align: center;
  }
	  .top-features-production-item-head {
    padding: 0 0 18px;
    text-align: left;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-align-items: center;
    align-items: center;
  }
  .top-features-production-item-head.salon-c {
    -webkit-align-items: flex-start;
    align-items: flex-start;
  }
	}

/* ==========================================================================
	下層ページ
========================================================================== */
.pagetitle{ 
max-width: 1200px;  /* 最大幅決める（例えばPCでの最大） */
  width: 90%;         /* 常に全体の80%幅にする */
  margin: 0 auto;     /* 中央寄せ */
  padding: 10% 10px 0; /* 上下に余白、左右少しスペース */
}



.course .donyu { text-align: center;}

@media screen and (max-width: 819px) {
	.pagetitle{ padding-top:15%;}
	.course .donyu { text-align: left; padding: 0 5%; line-height: 1.7;}
	
}

.breadcrumb {
  display: block;
  width: 100%;
  overflow-x: auto;
  white-space: nowrap;
  padding: 0;
  margin-bottom: 5%;
  font-size: 14px;
}

.breadcrumb ol {
  display: flex;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0.5em;
}

.breadcrumb li {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
}

.breadcrumb li + li::before {
  content: "›";
  margin: 0 0.5em;
  color: #aaa;
}

.breadcrumb a {
  text-decoration: none;
  color: #333;
}

@media screen and (max-width: 819px) {
  .breadcrumb {
    font-size: 11px;
	  padding-top: 2%;
  }

  .breadcrumb li {
    font-size: 0.75rem;
  }
}



/* ==========================================================================
	教室ページ
========================================================================== */


.course-select {
  width: 100%;
  max-width: 1350px;
  margin: 0 auto;
  padding: 0 5%;

}

.course-select h2 {
  margin-bottom: 5vw;
  display: flex;
  align-items: center;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
	font-weight: 600;
}

.course-select h2::before,
.course-select h2::after {
  content: '';
  height: 1px;
  background: #d6d1c9;
  flex: 1;
  margin: 0 4vw;
}

@media screen and (max-width: 768px) {
	.course-select h2::before,
.course-select h2::after {display:none;
}
	
}

.course-select-items {	
  display: flex;
  flex-direction: column;
  gap: 8vw;
  padding: 0;
  margin: 0;
	margin-top: 5%;
}

.course-select-items li {
  width: 100%;
  list-style: none;
}
.course-select-items p{
  text-align: left;
}

.course-select-item-image img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.course-select-item-text {
  width: 90%;
  margin: -12vw auto 0;
  padding: 5vw 3vw;
  text-align: center;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 0 12px rgba(0, 0, 0, 0.1);
  position: relative;
}

.course-select h3 {
	color: #e26c63;
	font-size: 1.7rem;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "MS P明朝", serif;
	font-weight: 600;
  display: block;
  position: relative;
}

@media screen and (max-width: 768px) {
	.course-select h3 { line-height:120%; 
	margin-bottom:2%;}
}

.course-select h3::after {
  content: '';
  width: 10vw;
  height: 1px;
  background: var(--gold01);
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.course-select .example {
padding: 1% 5%;
  margin: 0 1% 2vw 0; /* 横の隙間 */
  color: #ffffff;
  border: 1px solid #d0942b;
  background-color: #d0942b;
  display: inline-block;
	font-size: 0.7rem;
}

.course-select .pricebox,
.course-select .pricebox p,
.course-select .pricebox span{
	text-align: center;
}

.course-select .detail {margin: 0;
	padding-bottom: 0;
color: #666666;}

.course-select .pricebox{margin-top: 3%; margin-bottom: 3%;}
.course-select .price{ font-size: 2.7rem;
font-family: "adobe-kis-variable", sans-serif;
font-variation-settings: "wght" 300, "opsz" 12;}

	
.course-select .en { font-size: 1.4rem; color: #b47928; letter-spacing: 0.05rem; }

/* ===== PC用スタイル（820px〜） ===== */

@media screen and (min-width: 820px) {
  .course-select-items {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 40px;
  }

  .course-select-items li {
    width: calc(50% - 20px); /* 2列でgap考慮 */
    margin-bottom: 40px;
  }

  .course-select-item-image {
    width: 100%;
  }

	  .course-select-items {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 40px;
  }


	
  .course-select-item-image img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
  }
.course-select .pricebox{margin-top: 5%;　margin-bottom: 5%;}
  .course-select-item-text {
    padding: 20px;
	  margin: -6vw auto 0;
    background: rgba(255,255,255,0.95);
    text-align: center;
  }
	  .course-select .example {
    margin: 0 8px 0 0;
     text-align: center;
		  font-size: 0.9rem;
  }

}


/* ==========================================================================
	banner
========================================================================== */
.banners {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  max-width: 1200px;
  margin: 40px auto;
  padding: 0 20px;
}

/* 各バナー要素（最大幅を設定） */
.banner {
  flex: 1 1 100%;
  max-width: 100%;
  text-align: center;
}

/* 画像のサイズを制御（横幅100%以下になるように） */
.banner img {
  width: 100%;
  max-width: 400px; /* 例：PC時の最大横幅 */
  height: auto;
  display: inline-block;
}

/* タブレット以上で2列 */
@media screen and (min-width: 768px) {
  .banner {
    flex: 1 1 calc(50% - 10px);
    max-width: calc(50% - 10px);
  }
}

/* PC以上で3列 */
@media screen and (min-width: 1024px) {
  .banner {
    flex: 1 1 calc(33.333% - 13.33px);
    max-width: calc(33.333% - 13.33px);
  }
}

  .formbox {
    margin-bottom: 20px;
  }

  .formbox .bold {
    font-weight: bold;
    margin-bottom: 8px;
    display: block;
  }

  .form100, .formtel, .formtxt, input[type="text"], input[type="email"], textarea {
    width: 100%;
    max-width: 600px;
    padding: 10px 12px;
    border: 1px solid #ccc;
    font-size: 16px;
    box-sizing: border-box;
  }

  .formtxt {
    height: auto;
    min-height: 180px;
  }

  .formbtn {
    background-color: #c7b99f;
    color: #fff;
    padding: 12px 24px;
    border: none;
    font-size: 16px;
    margin: 10px 8px;
    cursor: pointer;
    border-radius: 4px;
  }

  .formbtn:hover {
    background-color: #b2a282;
  }

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

  @media (max-width: 768px) {
    .formbtn {
      width: 90%;
      margin: 10px auto;
      display: block;
    }
  }
/* ==========================================================================
	contact
========================================================================== */
.line-banner {
  display: block;
  margin: 0 auto;
  width: 50%;
	margin-bottom:5%;
}
@media screen and (max-width: 767px) {
  .line-banner {
    width: 100%;
  }
}

/* ==========================================================================
	カテゴリー
========================================================================== */
.category-page {
  max-width: 1000px;
  margin: 0 auto;
  padding: 2rem 0;
}

.category-title {
  font-size: 2rem;
  margin-bottom: 2rem;
}

.post-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.post-item {
  border: 1px solid #ddd;
  padding: 1rem;
  background: #fff;
  transition: box-shadow 0.3s;
}

.post-item:hover {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.post-item a {
  display: flex;
  flex-direction: column; /* スマホでは縦並び */
  text-decoration: none;
  color: inherit;
  gap: 1rem;
}

.post-thumbnail {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  flex-shrink: 0;
}

.post-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.post-content {
  flex: 1;
}

.post-title {
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 0.5rem;
  color: #333;
}

.post-date {
  font-size: 0.9rem;
  color: #888;
  margin-bottom: 0.8rem;
}

.post-excerpt {
  word-break: break-word; /* 長い単語でも途中で折り返す */
  line-height: 1.6;
}

/* ---------- PC時の横並び ---------- */
@media screen and (min-width: 768px) {
  .post-item a {
    flex-direction: row;
    align-items: flex-start;
  }

  .post-thumbnail {
    width: 100px;
  }

  .post-content {
    padding-top: 0;
  }
}

/* ---------- BLOG ---------- */
.example {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4em;
  font-size: 0.85rem;
}

/* ------ お知らせ一覧 --------- */

.post-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.post-item {
  display: flex;
  align-items: flex-start;
  gap: 1em;
  border-bottom: 1px solid #ccc;
  padding: 1em 0;
	padding-left:1em;
}

.post-item a {
  display: flex;
  text-decoration: none;
  color: inherit;
  gap: 1em;
  flex-direction: row;
}

.thumb-wrap {
  flex: 0 0 120px;
}

.thumb {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 4px;
}

.text-wrap {
  flex: 1;
}

.text-wrap h2 {
  font-size: 1.1em;
  margin: 0 0 0.5em;
}

.text-wrap .date,
.text-wrap .category {
  font-size: 0.7em;
  color: #999;
  margin-bottom: 0.5em;
}

.text-wrap .excerpt {
  font-size: 0.8em;
  line-height: 1.4;
}
.text-wrap .category{
    padding: 0.1vw 2vw;
     color: #ffffff;
    background-color: #fe797a;
    -moz-border-radius: 5vw;
    -webkit-border-radius: 5vw;
    border-radius: 2vw;
    display: table;
}

@media screen and (max-width: 768px) {
  .post-item {
    flex-direction: column;
	  padding:1em;
  }

  .post-item a {
    flex-direction: column;
  }

  .thumb-wrap {
    width: 100%;
    margin-bottom: 0.5em;
  }

  .thumb {
    width: 100%;
  }
}
/* ------改行 --------- */
.sp-only {
  display: none;
}

@media screen and (max-width: 768px) {
  .sp-only {
    display: inline;
  }
}

.pc-only {
  display: inline;
}

@media screen and (max-width: 768px) {
  .pc-only {
    display: none;
  }
}


.course-block {
  padding: 1.5em;
  background-color: #ffffff;
  border-radius: 8px;
  border: 1px solid #e0d7cf;
	margin-bottom:5%;
	
}

.course-level-title {
  font-size: 1.2rem;
  color: #b76c6c;
  margin-bottom: 1em;
  font-weight: bold;
  text-align: left;
}

.course-level-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.course-level-list li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0.8em 0;
  border-bottom: 1px solid #e8e3df;
  font-size: 0.98rem;
}

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

.course-level-list .level {
  font-weight: bold;
  color: #333;
  width: 20%;
}

.course-level-list .detail {
  width: 50%;
  color: #666;
}

.course-level-list .price {
  width: 30%;
  text-align: right;
  font-weight: bold;
  color: #b76c6c;
}


.pc-eyecatch img {
  width: 100%;
  max-width: 600px;
  height: auto;
  display: inline-block;
}

@media (min-width: 768px) {
  .pc-eyecatch img {
    width: 50%;
  }
}


/* 全体の枠 */
.category-box {
  border: 2px solid #ccc;
  border-radius: 12px;
  padding: 20px;
  margin: 30px 0;
  background-color: #fafafa;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

/* タイトル（任意） */
.category-box-title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 16px;
  color: #333;
  text-align: center;
}

/* カテゴリ一覧（個別バッジ風） */
.category-list ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-left: 0;
  list-style: none;
  margin: 0;
  justify-content: center; /* 中央寄せしたい場合 */
}

.category-list li {
  font-size: 12px;
  background-color: #f0f0f0;
  border-radius: 16px;
  padding: 6px 12px;
  transition: background-color 0.2s ease;
}

.category-list li a {
  text-decoration: none;
  color: #333;
  display: block;
}

.category-list li:hover {
  background-color: #e0e0e0;
}

.blog a {
  color: #c2185b; /* 濃いピンクで視認性アップ */
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: bold;
  transition: all 0.2s ease;
}

.blog a:hover {
  color: #e91e63;
  background-color: #fff0f5;
  border-radius: 4px;
  text-decoration: none;
  border-bottom: 2px solid #e91e63;
}



/* ページネーション全体 */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin: 40px 0;
  font-size: 14px;
}

/* 各リンクの基本スタイル */
.pagination .page-numbers {
  display: inline-block;
  padding: 8px 14px;
  border: 1px solid #ddd;
  border-radius: 4px;
  text-decoration: none;
  color: #555;
  background: #fff;
  transition: all 0.2s ease-in-out;
}

/* ホバー時 */
.pagination .page-numbers:hover {
  background: #f5f5f5;
  border-color: #aaa;
  color: #000;
}

/* 現在のページ */
.pagination .page-numbers.current {
  background: #cda4b1;   /* ブランドカラー（例: ピンク系） */
  border-color: #cda4b1;
  color: #fff;
  font-weight: bold;
  cursor: default;
}

/* 前へ・次へ */
.pagination .prev,
.pagination .next {
  font-size: 13px;
  padding: 8px 12px;
  color: #666;
}
