@charset"utf-8";

@media screen and (max-width: 768px) {

	/*common--------------------------------*/

	body{
		overflow-x: hidden;
	}

	#wrap {
		overflow-x: hidden;
	}

	:root {
		font-size: 2.42vw;
	}

	.sp {
		display: block;
		width: 100%;
		height: auto;
		padding: 0;
		margin: 0;
	}

	.pc {
		display: none;
	}
	
	.hover:hover {
		opacity: 1;
	}

	section {
		padding: 14.49vw 0;
	}

	.flex_container {
		display: block;
	}

	.sec_ttl {
		padding-bottom: 10.67vw;
	}
	
	.sec_ttl strong {
		font-size: 3rem;
	}

	.sec_ttl strong span {
		font-size: 2.4rem;
	}

	.lead_txt {
		font-size: 1.8rem;
	}
	
	.plain_txt {
		font-size: 1.6rem;
		font-weight: 500;
		color: var(--black);
		line-height: 2em;
		letter-spacing: .05em;
	}
	
	.btn_container {
		padding-top: 10.67vw;
	}
	
	.btn_container a {
		width: 70vw;
		height: 13.33vw;
		font-size: 1.8rem;
		margin: 0 auto;
	}
	
	.btn_container a::after {
		width: 14.49vw;
	}

	.plain_table th {
		font-size: 1.4rem;
		padding: 2.67vw;
	}

	.plain_table td {
		font-size: 1.4rem;
		padding: 2.67vw;
	}
	
	
	/*--------------------------------------*/
	
	/*header*/
	
	/*--------------------------------------*/
	
	header {
		padding: 3vw;
	}
	
	header .logo_container {
		position: relative;
		z-index: 99999;
	}
	
	header .logo_obj {
		width: 8vw;
		margin-right: 1.33vw;
	}
	
	header .logo_container strong {
		font-size: 1.6rem;
	}


	/*menu_trigger--------------------------------*/
	
	.menu_trigger {
		width: 9.66vw;
		height: 9.66vw;
		border-radius: 100vh;
		margin-top: .6vw;
		display: block;
		z-index: 99999;
		position: relative;
		transition: .2s ease-out;
	}
	
	.menu_trigger,
	.menu_trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	
	.menu_trigger span {
		position: absolute;
		left: 2.17vw;
		width: 8vw;
		height: 2px;
		background-color: var(--main-color);
		border-radius: 100vh;
		z-index: 4;
		-webkit-transition: .2s ease-out;
		transition: .2s ease-out;
	}
	
	.menu_trigger span:nth-of-type(1) {
		top: 1.67vw;
	}
	.menu_trigger span:nth-of-type(2) {
		top: 4.4vw;
	}
	.menu_trigger span:nth-of-type(3) {
		bottom: 1.67vw;
	}
	.menu_trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(2.78vw) rotate(-45deg);
		transform: translateY(2.78vw) rotate(-45deg);
	}
	
	.menu_trigger.active span:nth-of-type(2) {
		left: 100%;
		opacity: 0;
		-webkit-animation: active-menu-bar02 .8s forwards;
		animation: active-menu-bar02 .8s forwards;
	}
	
	.menu_trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-2.78vw) rotate(45deg);
		transform: translateY(-2.78vw) rotate(45deg);
	}

	.menu_target {
		width: 100vw;
		background-color: var(--white);
		padding: 19.32vw 5vw 10vw;
		box-sizing: border-box;
		box-shadow: 2px 2px 2px rgba(0,0,0,.4);
		position: absolute;
		top: -100vh;
		left: 0;
		z-index: 9999;
		transition: .5s ease-out;
	}

	.menu_target.active {
		top: 0;
		transition: .5s ease-out;
	}

	header nav,
	.nav_list_container {
		display: block;
	}
	
	.nav_list_item {
		text-align: center;
		border-bottom: 2px solid var(--pink);
		padding: 2.13vw 0;
	}
	
	.nav_list_item + .nav_list_item {
		padding-left: 0;
	}
	
	.nav_list_item a {
		font-size: 1.6rem;
	}
	
	.inquiry_btn_container {
		padding: 7.24vw 0 0;
	}
	
	.inquiry_btn_container a {
		height: 12.08vw;
		font-size: 1.8rem;
	}
	
	
	
	/*--------------------------------------*/
	
	/*footer*/
	
	/*--------------------------------------*/
	
	/*inquiry_wrap--------------------------------*/
	
	footer .inquiry_wrap {
		padding: 14.49vw 5vw;
		justify-content: center;
	}
	
	footer .inquiry_container {
		width: 90vw;
		padding: 5vw 3vw 8vw;
		box-sizing: border-box;
		display: block;
	}
	
	footer .inquiry_container .ttl_container {
		padding-right: 0;
	}
	
	footer .inquiry_container .sec_ttl, 
	footer .inquiry_container .plain_txt {
		padding-bottom: 5.33vw;
		text-align: center;
	}
	
	footer .inquiry_container .sec_ttl strong a {
		font-size: 3.6rem;
		letter-spacing: .05em;
	}
	
	footer .inquiry_container .btn_container {
		padding-top: 5.33vw;
	}
	
	footer .inquiry_container .btn_container a {
		width: 70vw;
	}
	
	
	/*footer_wrap--------------------------------*/
	
	.footer_wrap {
		padding: 10.67vw 0;
	}
	
	.footer_wrap .nav_list_container {
		padding-bottom: 10.67vw;
	}
	
	.footer_wrap .nav_list_item {
		border-bottom: none;
	}
	
	.footer_wrap .logo_obj {
		width: 10vw;
		margin-right: 1.33vw;
	}
	
	.footer_wrap .logo_container strong {
		display: block;
		font-size: 1.6rem;
		padding-top: 2.13vw;
	}
	
	.copy_wrap {
		padding: 2.13vw 0;
	}
	
	.copy_wrap small {
		font-size: 1.2rem;
	}
	
	
	/*--------------------------------------*/
	
	/*top*/
	
	/*--------------------------------------*/
	
	/*mv_wrap--------------------------------*/
	
	.mv_wrap,
	.mv_list_container {
		height: 70vh;
	}
	
	.mv_list_item {
		height: 70vh;
		padding: 0 3vw 3vh;
	}

	.mv_list_obj.first {
		background-position: 95.5% center;
	}

	.mv_list_obj.second {
		background-position: 39% center;
	}

	.mv_list_obj.third {
		background-position: 75% center;
	}
	
	.catch_container {
		left: 6vw;
		top: 75%;
	}
	
	.catch_container strong {
		font-size: 3.2rem;
	}
	
	
	
	/*sec01--------------------------------*/
	
	.latest_news_wrap {
		padding: 2.67vw 0 0;
	}
	
	.latest_news_wrap .content_container {
		padding: 5vw;
		display: block;
	}
	
	.latest_news_wrap .latestnews_ttl {
		text-align: center;
		padding: 0 0 5.33vw;
	}
	
	.latest_news_container a {
		display: block;
	}
	
	.latest_news_container a em,
	.latest_news_container a strong {
		display: block;
		font-size: 1.6rem;
	}
	
	.latest_news_container a em {
		width: 100%;
		padding-bottom: .5em;
	}
	
	.latest_news_container a strong {
		width: 100%;
	}
	
	
	
	/*sec02--------------------------------*/
	
	.top .studio_wrap .content_container {
		display: block;
	}
	
	.top .studio_wrap .ttl_container,
	.top .studio_wrap .bnr_list_container {
		width: 100%;
		height: unset;
		box-sizing: border-box;
	}
	
	.top .studio_wrap .ttl_container {
		padding: 0 0 10.67vw;
	}
	
	.top .bnr_list_container .slick-dots {
		bottom: 2.67vw;
	}
	
	
	
	/*sec03--------------------------------*/
	
	.top .class_wrap .plain_txt {
		text-align: left;
	}
	
	.top .class_list_container {
		display: block;
		padding-top: 10.67vw;
	}
	
	.top .class_list_item {
		width: 100%;
	}
	
	.top .class_list_item + .class_list_item {
		padding-top: 5.33vw;
	}
	
	
	
	/*sec04--------------------------------*/
	
	.top .news_wrap .content_container {
		display: block;
		position: relative;
	}
	
	.top .news_wrap .ttl_container {
		width: 100%;
		padding-bottom: 0;
	}
	
	.top .news_wrap .sec_ttl {
		padding-bottom: 2.67vw;
	}
	
	.top .news_wrap .btn_container {
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
	}
	
	.top .news_wrap .news_list_container {
		width: 100%;
		padding-bottom: 24.15vw;
	}
	
	.top .news_wrap .news_list_item {
		padding: 7.25vw 0 2.67vw;
	}
	
	.top .news_wrap .news_list_item a.flex {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
	}
	
	.top .news_wrap .news_list_item a.flex .txt_container {
		width: 100%;
	}
	
	.top .news_wrap .news_list_item a.flex .img_container {
		width: 100%;
		aspect-ratio: 16 / 9;
		padding-bottom: 5.33vw;
	}
	
	.top .news_wrap .news_list_item em {
		font-size: 1.4rem;
		padding-bottom: 1.33vw;
	}
	
	.top .news_wrap .news_list_item strong {
		font-size: 1.6rem;
		line-height: 1.3em;
	}


	/*--------------------------------------*/

	/*lower*/

	/*--------------------------------------*/

	/*mv_wrap--------------------------------*/

	.lower .mv_wrap {
		height: 30vw;
	}

	.lower .mv_container {
		width: 96vw;
		border-radius: 10px;
		background: url('../img/common/mv_obj.webp') center 70% / cover no-repeat;
	}

	.lower .catch_container {
		top: 50%;
	}

	.lower .catch_container strong {
		font-size: 2.2rem;
	}


	/*--------------------------------------*/

	/*studio*/

	/*--------------------------------------*/

	/*sec01--------------------------------*/

	.studio .studio_wrap .txt_container,
	.studio .studio_wrap .img_container {
		width: 100%;
	}
	.studio .studio_wrap .img_container {
		height: 60vw;
		padding-top: 2.67vw;
	}

	.studio .studio_wrap .flex_container + .flex_container {
		padding-top: 10.67vw;
		flex-direction: unset;
	}

	.studio .studio_wrap .img_container .studio_obj::after {
		width: 101%;
		height: 40%;
		background: linear-gradient(to top,rgba(255,249,253,0) 0, rgba(255,249,253,1) 80%);
	}

	.studio .studio_wrap .flex_container:nth-of-type(even) .img_container .studio_obj::after {
		background: linear-gradient(to top,rgba(255,249,253,0) 0, rgba(255,249,253,1) 80%);
	}


	/*sec02--------------------------------*/

	.studio .graduates_wrap .plain_txt span {
		white-space: wrap;
		display: block;
		padding-left: 0;
		font-size: 1.4rem;
	}

	.studio .graduates_list_container {
		display: block;
		padding-bottom: 7.24vw;
	}

	.studio .graduates_list_item {
		width: 100%;
		padding-bottom: 2.67vw;
	}

	.studio .graduates_list_item + .graduates_list_item {
		padding-top: 5.33vw;
	}

	.studio .graduates_list_obj {
		width: 100%;
	}

	.studio .graduates_list_ttl {
		padding-top: 1.33vw;
	}

	.studio .graduates_list_ttl strong {
		font-size: 1.6rem;
	}

	.studio .graduates_list_ttl i {
		font-size: 1.4rem;
	}

	.studio .modal_wrap .modal_list_container.current {
		width: 90vw;
		height: 70vh;
	}

	.studio .modal_wrap .modal_list_item {
		width: 90vw;
		height: 70vh;
		padding: 0 5vw;
		display: flex;
		align-items: center;
	}

	.studio .modal_list_obj {
		width: 100%;
		height: unset;
	}

	.studio .slick_prev {
		width: 7.24vw;
		height: 7.24vw;
		left: -2.5vw;
	}

	.studio .slick_next {
		width: 7.24vw;
		height: 7.24vw;
		right: -2.5vw;
	}

	.studio .btn_close {
		font-size: 5.2rem;
	}


	/*sec03--------------------------------*/

	.studio .staff_wrap .staff_ttl {
		font-size: 2.2rem;
		padding-bottom: 5.33vw;
		text-align: center;
	}

	.studio .staff_wrap .img_container {
		width: 70vw;
		margin: 0 auto;
		padding-bottom: 5.33vw;
	}

	.studio .staff_wrap .txt_container {
		width: 100%;
	}

	.studio .staff_wrap .staff_subttl {
		font-size: 2.2rem;
		text-align: center;
		padding-bottom: 2.67vw;
	}

	.studio .staff_wrap .profile_list_container dt {
		font-size: 1.4rem;
	}

	.studio .staff_wrap .profile_list_container dd {
		font-size: 1.4rem;
	}


	/*sec04--------------------------------*/

	.studio .location_list_container {
		flex-wrap: wrap;
		padding-bottom: 5.33vw;
	}

	.studio .location_list_item:nth-child(1) {
		width: 40%;
	}

	.studio .location_list_item:nth-child(2) {
		width: 56%;
	}

	.studio .location_list_item:nth-child(3) {
		width: 100%;
		padding-top: 4vw;
	}

	.studio .location_list_container .location_list_obj {
		height: 100%;
	}

	.studio .map_container {
		margin-top: 20px;
	}

	.studio .map_container iframe {
		height: 84.54vw;
	}


	/*--------------------------------------*/

	/*class*/

	/*--------------------------------------*/

	/*calendar_wrap--------------------------------*/

    .calendar_wrap iframe {
        height: 145vw;
    }


	/*sec02--------------------------------*/

	.class .class_wrap .lead_txt + .plain_txt {
		transform: translateY(0);
		padding-bottom: 1.5em;
	}

	.class .class_list_item + .class_list_item {
		padding-top: 0;
	}

	.class .class_list_item .class_subttl {
		font-size: 2.4rem;
		line-height: 1.2em;
		padding-bottom:  .5em;
	}

	.class .class_list_item:nth-child(odd) .class_subttl {
		text-align: left;
	}

	.class .class_list_item .flex_container,
	.class .class_list_item .img_container {
		width:100%;
	}

	.class .class_list_item .txt_container {
		width: 85vw;
		padding: 3vw;
		transform: translate(2.5vw, -10vw);
	}

	.class .class_list_item .class_ttl,
	.fee_wrap .fee_ttl {
		padding-bottom: 5.33vw;
	}

	.class .class_list_item .class_ttl strong,
	.fee_wrap .fee_ttl strong {
		font-size: 2rem;
		line-height: 2em;
	}

	.class .class_list_item .class_ttl em {
		font-size: 1.2rem;
	}

	.class .class_list_item .class_ttl span::before,
	.fee_wrap .fee_ttl span::before {
		height: .8em;
		top: 50%;
	}

	.class .class_list_item .lead_txt {
		font-size: 1.6rem;
		line-height: 1.64em;
		padding-bottom: 1em;
	}

	.class .class_list_item .plain_txt {
		font-size: 1.4rem;
	}

	.class .class_list_item:nth-child(even) .txt_container {
		transform: translate(2.5vw, -5vw);
	}

	.fee_wrap .note_list_container {
		padding-top: 1em;
	}

	.fee_wrap .note_list_item {
		font-size: 1.2rem;
	}

	.fee_wrap {
		padding-top: 0;
	}



	/*--------------------------------------*/

	/*trial*/

	/*--------------------------------------*/

	/*sec01--------------------------------*/

	.trial .flex_container .img_container {
		width: 100%;
	}

	.trial .flex_container .txt_container {
		width: 100%;
	}

	.trial .flex_container .txt_container .tel_container {
		padding-top: 5.33vw;
		text-align: center;
	}

	.trial .flex_container .txt_container .tel_container a {
		font-size: 4rem;
	}

	.trial .flex_container .img_container {
		height: 65vw;
		padding-bottom: 5.33vw;
	}

	.trial .flex_container .txt_container .btn_container {
		padding-top: 5.33vw;
	}

	.trial .flex_container .txt_container .btn_container a {
		font-size: 1.8rem;
	}

	.trial .fee_wrap {
		padding-top: 10.67vw;
	}

	.trial .plain_table td i {
		font-size: 1.2rem;
	}

	/*sec02--------------------------------*/

	.trial .trial_ttl {
		padding-bottom: 5.33vw;
	}

	.trial .trial_ttl strong {
		font-size: 2rem;
	}

	.trial .trial_ttl span::before {
		height: .8em;
		top: 50%;
	}



	/*--------------------------------------*/

	/*news*/

	/*--------------------------------------*/

	/*sec01--------------------------------*/

	.news .news_wrap .news_list_container {
		width: 90vw;
		max-width: 1000px;
		border-top: 3px solid var(--gold);
		margin: 0 auto;
	}

	.news .news_wrap .news_list_item {
		width: 100%;
		border-bottom: 1px solid var(--gold);
		padding: 30px 0;
	}

	.news .news_wrap .news_list_item a.flex {
		display: flex;
		flex-direction: row-reverse;
		justify-content: space-between;
	}

	.news .news_wrap .news_list_item a.flex .txt_container {
		width: 65%;
	}

	.news .news_wrap .news_list_item a.flex .img_container {
		width: 30%;
		aspect-ratio: 4 / 3;
	}

	.news .news_wrap .news_list_item a.flex .news_list_obj {
		display: block;
		width: 100%;
		height: 100%;
		background-position: center center;
		background-repeat: no-repeat;
		background-size: cover;
	}

	.news .news_wrap .news_list_item em {
		font-size: 1.6rem;
		font-weight: 700;
		font-style: normal;
		color: var(--lightgray);
		letter-spacing: .05em;
		line-height: 1em;
		display: block;
		padding-bottom: 10px;
	}

	.news .news_wrap .news_list_item strong {
		font-size: 1.8rem;
		font-weight: 500;
		font-style: normal;
		color: var(--black);
		letter-spacing: .05em;
		line-height: 1.64em;
	}


	/*post_container--------------------------------*/

    .news .post_container img {
        margin-bottom: 4.83vw;
    }

    .news .post_container h1 {
        font-weight: 11.59vw;
    }

    .news .post_container h2 {
        font-weight: 13.53vw;
    }

    .news .post_container h3 {
        font-weight: 7.73vw;
    }

    .news .post_container h4 {
        font-weight: 5.8vw;
    }

    .news .post_container h5 {
		font-size: 4.83vw;
    }

    .news .post_container h6 {
		font-size: 4.35vw;
    }
	
	.news .post_container p {
		font-size: 4.35vw;
	}

	.news .post_container .img_container {
		width: 100%;
	}
	.news .post_container ul > li {
		font-size: 4.35vw;
	}
	.news .post_container ol > li {
		font-size: 4.35vw;
	}
	.news .post_container blockquote {
		font-size: 4.35vw;
		padding: 0 10px;
	}
	.news .post_container blockquote:before {
        font-weight: 13.53vw;
		padding-top: 0;
	}
	.news .post_container blockquote:after {
		content: '”';
        font-weight: 13.53vw;
	}



	/*--------------------------------------*/

	/*inquiry*/

	/*--------------------------------------*/

	/*input--------------------------------*/

	.inquiry_wrap .inquiry_list_container {
		display: block;
		background-color: var(--white);
		padding: 2.67vw;
	}

	.inquiry_wrap .inquiry_list_container dt {
		width: 100%;
		padding: 2.67vw;
		font-size: 1.6rem;
	}

	.inquiry_wrap .inquiry_list_container dd {
		width: 100%;
		padding: 2.67vw 0;
		font-size: 1.6rem;
		margin: 0;
		display: block;
	}

	.inquiry_wrap .inquiry_list_container.comfirm dd {
		padding: 2.67vw 0 2.67vw 2.67vw;
	}

	input[type="text"],
	input[type="password"] {
		width: 100%;
		height: 12vw;
		font-size: 1.6rem;
		padding: 2.67vw;
	}

	input:focus,
	textarea:focus {
		outline: 3px solid var(--pink);
	}

	textarea {
		font-size: 1.6rem;
		padding: 2.67vw;
	}

	.req {
		font-size: 1.1rem;
		margin-left: 2.67vw;
	}

	.submit_container {
		padding-top: 7.25vw;
	}

	label {
		font-size: 1.6rem;
	}

	input[type="submit"] {
		width: 80vw;
		height: 12.08vw;
		font-size: 1.8rem;
		line-height: 12.08vw;
	}


	.inquiry_wrap .btn_container.back {
		padding-top: 10.67vw;
	}

	.inquiry_wrap .center {
		text-align: left;
	}

	.inquiry_wrap .center.mail {
		padding: 5.33vw 0 10.67vw;
	}

	.inquiry_wrap .plain_txt,
	.section ul {
		padding-bottom: 1em;
	}

	.inquiry.confirm .plain_txt,
	.inquiry.finish .plain_txt {
		color: #333;
		font-size: 1.6rem;
	}

	.inquiry_txt {
		font-size: 1.6rem;
		text-align: left;
	}




/*-------------------------------------*/
}