@charset "utf-8";

@media screen and (max-width: 768px) {
   
/*	html {
		overscroll-behavior: none;
	}*/
	body {
    -webkit-text-size-adjust: none;		
  }
	
	p {
		font-size: 14px;
	}
   
  br.sp {
    display: inline !important;
  }
  br.pc,img.pc,span.sp_non {
    display: none;
  }
	img.sp {
		display: inline-block;
	}
	
	.wp-block-embed iframe {
		width: 100%;
		height: 100%;
		aspect-ratio: 16 / 9;
	}
      
    
  .sa--left {
    transform: translate(10px, 0);
  }
  .sa--right {
    transform: translate(-10px, 0);
  }
  .sa--up {
    transform: translate(0, 10px);
  }
  .sa--down {
    transform: translate(0, -10px);
  }
	.sa--sp {
		transform: translate(0,10px) rotate(10deg);
	}
	
	
	/*===== header =====*/
	header {
		position: fixed;
		left: 0;
		top: 0;
		z-index: 50000;
		width: 100%;
	}

	header .inner {
		width: 100%;
		padding: 22px 25px 0;
	}
	header h1 {
		width: 45px;
	}
	
	
	/*===== menu =====*/
	#menu {
		height: 100dvh;
		overflow-y: scroll;
		opacity: 0;
	}

	#menu .inner {
		position: relative;
		width: 100%;
		padding: 23px 25px 144px;
	}
	#menu .inner .h {
		margin-bottom: 32px;
	}
	#menu .inner .h .logo {
		width: 51px;
	}
	#menu .inner .h .close_btn {
		width: 20px;
	}

	#menu .inner .box {
		display: block !important;
		width: 100%;
		padding: 0 12px;
		margin: 0;
	}

	#menu .inner .box ul.list {
		width: 100%;
	}
	#menu .inner .box ul.list > li > a {
		font-size: 16px;
		letter-spacing: 0.16em;
		padding: 14px 0 12px;
	}
	#menu .inner .box ul.list > li > a > span {
		font-size: 10px;
		margin-top: 6px;
	}
	#menu .inner .box ul.list > li ol {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		padding-bottom: 12px;
	}
	#menu .inner .box ul.list > li ol::after {
		content: "";
		display: block;
		position: absolute;
		left: 50%;
		top: 0;
		width: 1px;
		height: calc(100% - 10px);
		background-color: rgba(255,255,255,0.5);
	}
	#menu .inner .box ul.list > li ol li {
		width: calc((100% - 32px) / 2);
		margin-bottom: 0;
	}
	#menu .inner .box ul.list > li ol li a {
		font-size: 14px;
		width: 100%; 
		background: url("../img/link_mark2.png") no-repeat 100% 0 / 13px 13px;
	}
	#menu .inner .box ul.list > li ol li a::before {
		display: none;
	}

	#menu .inner .box .sub {
		width: 100%;
	}

	#menu .inner .box .sub ul.form {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 15px 0 20px;
	}
	#menu .inner .box .sub ul.form li {
		width: calc((100% - 17px) / 2);
	}
	#menu .inner .box .sub ul.form li:nth-of-type(1) {
		margin-bottom: 0;
	}
	#menu .inner .box .sub ul.form li a {
		font-size: 14px;
		height: 35px;
		padding: 10px 0 0 47px;
		border-radius: 4.2px;
	}
	#menu .inner .box .sub ul.form li:nth-of-type(1) a {
		background: #fff url("../img/calender.png") no-repeat 15px 50% / 18px 19px;
	}
	#menu .inner .box .sub ul.form li:nth-of-type(2) a {
		background: #fff url("../img/mail.png") no-repeat 15px 50% / 19px 14px;
	}

	#menu .inner .box .sub ul.sns {
		padding-left: 0;
	}
	#menu .inner .box .sub ul.sns li {
		margin-right: 20px;
	}
	#menu .inner .box .sub ul.sns li img {
		width: 28px;
		height: 28px;
	}

	#menu .inner .box .sub .banner {
		font-size: 16px;
		margin-top: 33px;
	}
	#menu .inner .box .sub .banner a {
		display: block;
		width: 100%;
		height: 123px;
		margin-top: 15px;
	}

	#menu .inner .img {
		left: auto;
		right: 25px;
		bottom: -40px;
		width: 174px;
		height: 116px;
	}
	
	
	/*===== footer =====*/
	footer {
		padding: 60px 35px 70px;
	}

	footer .inner {
		display: block !important;
		width: 100%;
	}

	footer .logo {
		width: 79px;
		margin: 0 auto 30px;
	}

	footer ul.list {
		width: 100%;
		height: auto;
	}
	footer ul.list::after {
		display: none;
	}
	footer ul.list > li {
		font-size: 16.2px;
		width: 100%;
		margin-bottom: 0;
	}
	footer ul.list > li ol {
		padding: 20px 0 25px;
	}
	footer ul.list > li ol li {
		font-size: 15px;
		margin-bottom: 15px;
	}
	footer ul.list > li ol li a {
		width: 100%;
		padding-bottom: 9px;
		background: url("../img/link_mark2.png") no-repeat calc(100% - 15px) 0 / 15px 15px;
	}
	footer ul.list > li ol li span {
		position: absolute;
		right: 38px;
		top: 0;
		font-size: 13px;
	}

	footer .sub {
		display: flex;
		justify-content: space-between;
		width: 100%;
		margin-left: 0;
	}

	footer .sub ul.form {
		width: 150px;
		margin-bottom: 0;
	}
	footer .sub ul.form li:nth-of-type(1) {
		margin-bottom: 25px;
	}
	footer .sub ul.form li a {
		font-size: 14px;
		height: 35px;
		padding: 10px 0 0 50px;
		border-radius: 4.3px;
	}
	footer .sub ul.form li:nth-of-type(1) a {
		background: #fff url("../img/calender.png") no-repeat 17px 50% / 18px 18.5px;
	}
	footer .sub ul.form li:nth-of-type(2) a {
		background: #fff url("../img/mail.png") no-repeat 17px 50% / 20px 15px;
	}

	footer .sub ul.sns {
		padding-left: 0;
	}
	footer .sub ul.sns li {
		margin: 0 0 0 20px;
	}
	footer .sub ul.sns li img {
		width: 25px;
		height: 25px;
	}

	footer .copy {
		font-size: 10px;
		text-align: center;
		margin-top: 40px;
	}
	
	
	/*===== Top Page =====*/
	a.btn {
		font-size: 14px;
		line-height: 1em;
		width: 168px;
		height: 40px;
		padding: 12px 0 0 20px;
		border-radius: 20px;
	}
	a.btn::after {
		right: 20px;
		width: 14px;
		height: 14px;
		background: url("../img/link_mark1.png") no-repeat 0 0 / 14px 14px;
	}
	
	/*----- first_text -----*/
	#first_text {
		height: 100svh;
		overflow: hidden;
	}
	#first_text img.text {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		z-index: 10;
		transform: translate(-50%, -50%);
		transition: all 1s;
		opacity: 0;
		width: 246px;
		height: auto;
	}	
	#first_text.show img.text {
		opacity: 1;
	}

	/*----- FV -----*/
  #fv {
    display: block;
    width: 100%;
    height: 100svh;		
  }
	
	#fv .logo {
		left: 25px;
		top: 22px;
		width: 120px;
	}
	
  #fv .left,
  #fv .right {
    width: 100%;
    height: 50svh;		
  }
  #fv .left {
    padding: 0;
  }
  #fv .right {
    padding: 0;
  }
  #fv .sl,
	#fv .sr	{		
		width: 240px;
	}
  #fv .sl {
    right: 50%;
		transform: translate(50%,-50%);
  }
  #fv .sr {
    left: 50%;
		transform: translate(-50%,-50%);
  }
  #fv .mae,
  #fv .ato {
    font-size: 35px;
  }
  #fv .mae {
    right: 20px;
    top: 50%;
		transform: translate(0,-50%);
  }
  #fv .ato {
    left: 20px;
    bottom: 50%;
		transform: translate(0,50%);
  }
  
  #fv .scrolldown {
    right: 30px;
  }
  #fv .scrolldown:before {
    left: -3px;
    width: 7px;
    height: 7px;
    animation:
    circlemove_sp 3.0s ease-in-out infinite,
    cirlemovehide 3.0s ease-out infinite;
  }
  #fv .scrolldown:after{
    height: 88px;
  }
	#fv .scrolldown .sc {
		display: none;
	}
	
	/*----- about ----*/
	#top_about {
		padding: 75px 30px;
		background-image: linear-gradient(180deg, rgba(255, 255, 255, 1), rgba(236, 235, 235, 1) 50%, rgba(215, 215, 215, 1));
	}

	#top_about .inner {
		display: block;
		width: 100%;
		padding-left: 0;
	}
	
	#top_about .inner img.i01,
	#top_about .inner img.i02,
	#top_about .inner img.i03,
	#top_about .inner img.i04 {
		animation: fluffy_sp 3s infinite;
	}
	#top_about .inner img.i01 {
		left: 0;
		right: auto;
		top: auto;
		bottom: 305px;
		width: 43px;	
	}
	#top_about .inner img.i02 {
		left: 120px;
		right: auto;
		top: auto;
		bottom: 345px;
		width: 36px;
		animation-delay: .5s;
	}
	#top_about .inner img.i03 {		
		right: 25px;
		top: auto;
		bottom: 290px;
		width: 31px;
		animation-delay: .8s
	}
	#top_about .inner img.i04 {
		left: 20px;
		right: auto;
		top: auto;
		bottom: 220px;
		width: 31px;
		animation-delay: 1.2s
	}

	#top_about .text {
		width: 100%;
	}
	#top_about .text h2 {
		position: static;
		left: auto;
		top: auto;
		transform: rotate(0deg) translate(0, 0);
		font-size: 14px;
		margin-bottom: 2em;
	}
	#top_about .text p {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 2em;	
		margin-bottom: 2em;	
	}
	#top_about .text p:first-of-type {
		font-size: 21px;
		letter-spacing: 0.18em;
		line-height: 1.66em;	
		margin-bottom: 1em;	
	}
	#top_about .text div p:nth-child(n+2)	{
		font-feature-settings: "palt";
	}
	#top_about .text div p:nth-child(n+2) br {
		display: none;
	}

	#top_about .img {
		width: 90%;
		margin: 80px 0 30px auto;
	}
	
	/*----- Lesson ----*/
	.lesson_s,
	.lesson_o {
		padding: 75px 0;
	}
	.lesson_o {
		padding-top: 125px;
	}

	.lesson_s h2 {
		font-size: 14px;
		margin-bottom: 30px;
	}
	.lesson_s h2 + div.text p {
		font-size: 18px;
		line-height: 1.66em;
		margin-bottom: 50px;
	}

	.lesson_s .wrap,
	.lesson_o .wrap {
		position: relative;
		width: 100%;
		padding: 0 24px;
		margin-left: 0;
	}
	.lesson_o .wrap {
		padding-bottom: 130px;
	}
	.lesson_s .wrap h3,
	.lesson_o .wrap h3 {
		position: static;
		left: auto;
		top: auto;
		font-size: 17px;
		text-align: center;
		margin-bottom: 30px;
	}
	.lesson_s .wrap h3 span,
	.lesson_o .wrap h3 span {
		display: inline-block;
		font-size: 17px;
		margin: 0 0 0 0.5em;
	}
	.lesson_s .wrap h3 img,
	.lesson_o .wrap h3 img {
		display: block;
		margin: 15px auto 0;
	}
	.lesson_s .wrap h3 img {
		width: 31px;
	}
	.lesson_o .wrap h3 img {
		width: 18px;
	}
	.lesson_s .wrap .img01,
	.lesson_o .wrap .img01 {
		width: 100%;
		height: 225px;
		margin-bottom: 25px;
	}
	.lesson_s .wrap .img02 {
		position: absolute;
		right: 10px;
		bottom: -115px;
		width: 137.5px;
		height: 181.5px;
	}
	.lesson_o .wrap .img02 {
		position: absolute;
		left: 20px;
		bottom: 0;
		width: 207px;
		height: 176px;
	}
	.lesson_o .wrap .text .inner {
		padding-left: 0;
	}
	.lesson_s .wrap .text p,
	.lesson_o .wrap .text p {
		font-size: 14px;
		letter-spacing: 0.06em;
		line-height: 1.857em;
	}
	.lesson_s .wrap .text a,
	.lesson_o .wrap .text a {
		margin-top: 28px;
	}
	.lesson_o .wrap .text a {
		display: block;
		margin-right: 0;
		margin-left: auto;
	}
	
	/*----- staff -----*/
	#staff {
		display: block;
		width: 100%;
		padding: 75px 25px;
		margin-left: 0
	}
	#staff h2 {
		font-size: 14px;
		margin: 0 0 25px;
	}
	#staff .text p {
		font-size: 18px;
		line-height: 1.66em;
		font-feature-settings: "palt";
		margin-top: 0;
	}

	/*----- h_slide -----*/
	.h_slide {
		overflow: hidden;
	}
	.h_slide .swiper-slide {
		width: 835px !important;
		height: 230px !important;
	}
	
	#h_slide .m1 {
		left: auto;
		right: 27px;
		top: 27px;
		bottom: auto;
		width: 32px;
	}
	#h_slide .m2 {
		left: 20px;
		bottom: 25px;
		width: 54px;
	}
	
	/*----- professional -----*/
	#professional {	
		padding: 75px 0 150px;
	}
	#professional h2 {
		font-size: 14px;
		margin-bottom: 25px;
	}
	#professional .text p {
		font-size: 18px;
		line-height: 1.66em;
	}
	
	#professional .slide {
		position: relative;
		width: 315px;
		margin: 40px auto 0;
	}
	
	#professional .slide .arrow {
		top: 105px !important;
		height: 34px;
	}
	#professional .slide .arrow .p_member,
	#professional .slide .arrow .n_member {
		width: 34px !important;  
		height: 34px !important;
	}
	#professional .slide .arrow .p_member {
		left: 0 !important;
	}
	#professional .slide .arrow .n_member {
		right: 0 !important;
	}
	#professional .slide .arrow .p_member::after,
	#professional .slide .arrow .n_member::after {
		width: 34px;
		height: 34px;
		background-size: 34px 34px;
	}
	#professional .slide .arrow .p_member::after {
		background-image: url("../img/slide_arrow_prev_sp.png");
	}
	#professional .slide .arrow .n_member::after {
		background-image: url("../img/slide_arrow_next_sp.png");
	}

	#professional .slide .swiper-slide {
		width: 100%;
		height: auto !important;
		overflow: visible;
		margin-right: 0;
	}
	#professional .slide .swiper-slide .i {
		width: 190px;
		height: 215px;
		margin: 0 auto 20px;
	}
	#professional .slide .swiper-slide h4 {
		margin-bottom: 30px;
	}
	#professional .slide .swiper-slide h4::after {
		left: calc(50% - 32px);
		bottom: -15px;
		width: 64px;
	}
	#professional .slide .swiper-slide h4 div:first-of-type {
		font-size: 19px;
		letter-spacing: 0.12em;
		margin-bottom: 10px;
	}
	#professional .slide .swiper-slide h4 div:last-of-type {		
		font-size: 12px;
	}
	#professional .slide .swiper-slide .title {
		font-size: 14px;		
		line-height: 1.57em;
		height: 85px;
	}
	#professional .slide .swiper-slide a {
		font-size: 14px;
		width: 112px;
		height: 25px;
	}
	#professional .slide .swiper-slide a::after {
		top: 2px;
		width: 14px;
		height: 14px;
		background: url("../img/link_mark1.png") no-repeat 0 0 / 14px 14px;
	}
	
	/*----- news -----*/
	#news_top::before {
		content: "";
		display: block;
		position: absolute;
		left: 0;
		top: -65px;
		width: 100%;
		height: 70px;
		background: url("../img/arch_w_sp.png") no-repeat 50% 0 / 893px 88px;
	}
	
	#news_top #news_list {
		width: 100%;
		padding: 0 0 75px;
	}
	
	#news_top h2 {
		position: static;
		left: auto;
		top: auto;
		font-size: 14px;
		line-height: 1em;
		text-align: center;
		margin-bottom: 58px;
	}

	#news_top #news_list .post_list {
		width: 100%;
	}
	#news_top #news_list .post_list ul li {
		margin: 0 0 30px;
	}
	#news_top #news_list .post_list .btn_box {
		text-align: center;
	}

	
	/*===== common =====*/
	h3.midashi {
		font-size: 14px;
	}

	.page_h {
		width: 100% ;
		padding: 87px 0 50px;
	}
	.page_h h2 {
		font-size: 19px;
		padding: 0 25px;
		margin-bottom: 40px;
	}
	.page_h h2 span.e {
		font-size: 19px;
		margin: 0 0 11px;
	}
	.page_h h2 span {
		display: block;
		font-size: 12px;	
	}
	.page_h .i {
		width: 100%;
		height: 250px;
	}
	
	.read h3 {
		font-size: 14px;
		font-feature-settings: "palt";
	}
	.read h3 span {
		font-size: 20px;
		height: 33px;
		padding: 6px 23px 0 25px;
		margin: 15px auto 0;
	}
	
	.f_list {
		width: 100%;
		padding: 5px 30px 0;
	}
	.f_list ul {
		width: 100%;
	}
	.f_list ul li {		
		padding: 35px 0 30px;
		background-image: radial-gradient(circle, var(--gn1) 1px, transparent 1px);
		background-position: left bottom;
		background-repeat: repeat-x;
		background-size: 6px 2px;
	}
	.f_list ul li .h {
		font-size: 17px;
		letter-spacing: 0.15em;
		line-height: 1.588em;
		margin-bottom: 15px;
	}
	.f_list ul li .text {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.857em;
	}
	
	.cv {
		padding: 75px 0;
	}
	.cv h3 {
		font-size: 14px;
	}
	.cv .slide {
		width: 100%;
		padding-left: 25px;
		margin: 55px auto 30px;
	}
	.cv .slide .swiper-slide {
		width: 190px;
		overflow: visible;
		margin-right: 40px;
	}
	.cv .slide div.swiper-slide:last-of-type {
		margin-right: 25px;
	}
	.cv .slide .swiper-slide .i {
		width: 100%;
		height: 125px;
		margin-bottom: 20px;
	}
	.cv .slide .swiper-slide h4 {
		margin-bottom: 20px;
	}
	.cv .slide .swiper-slide h4 div:first-of-type {
		font-size: 16px;
		padding-bottom: 10px;
		margin-bottom: 15px;
	}
	.cv .slide .swiper-slide h4 div:first-of-type span {
		font-size: 10px;
	}
	.cv .slide .swiper-slide h4 div:first-of-type::after {
		left: calc(50% - 75px);
		width: 150px;
	}
	.cv .slide .swiper-slide h4 div:last-of-type {
		font-size: 13px;
	}
	.cv .slide .swiper-slide p {
		font-size: 14px;
		line-height: 1.857em;
	}
	
	
	/*===== About =====*/
	#about {
		padding: 0 0 75px;
	}
	#about .page_h {
		padding-bottom: 50px;
	}
	
	#about .page_h img.i01,
	#about .page_h img.i02 {
		animation: fluffy_sp 3s infinite;
	}
	#about .page_h img.i01 {		
		right: 26px;
		top: -29px;
		width: 72px;	
	}
	#about .page_h img.i02 {		
		left: 30px;
		bottom: -15px;
		width: 52px;	
	}
	
	#about .changes {
		position: relative;
		height: auto;
		padding: 0;
	}
	#about .changes .read {
		margin-bottom: 50px;
	}
	
	#about .changes .wrap {
		position: relative;
		padding-bottom: 25px;
	}
	#about .changes .unit {
		position: sticky;
		left: 15px;
		top: 65px;		
		width: calc(100% - 30px);
		min-height: 670px;
		padding: 30px 15px;
		background-color: #fff;
		margin-bottom: 25px;
		border: 2px solid var(--gn2);
		border-radius: 25px;
	}
	#about .changes .unit .no {
		position: absolute;
		left: 25px;
		top: 30px;
		color: var(--key);
		font-size: 34px;
		font-weight: 700;
		letter-spacing: 0.11em;
		line-height: 1em;
		text-decoration: underline;
		text-decoration-thickness: 1.5px;
		text-underline-offset: 12px;
	}
	#about .changes .unit .illust {
		text-align: center;
		margin-bottom: 15px;
	}
	#about .changes .unit .illust img {
		width: 166px;
		margin: auto;
	}
	#about .changes .unit .text p:first-of-type {
		font-size: 17px;
		letter-spacing: 0.14em;
		line-height: 1.64em;
		font-feature-settings: "palt";
		text-align: center;
		margin-bottom: 1em;
	}
	#about .changes .unit .text p:first-of-type span {
		display: inline-block;
		color: var(--key);
		font-size: 17px;
		line-height: 1em;
		padding: 3px 3px 3px 5px;
		background-color: var(--mark);
	}
	#about .changes .unit .text p:last-of-type {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.857em;
		font-feature-settings: "palt";
		text-align: center;
	}
	#about .changes .unit .zu {
		margin-top: 15px;
	}
	#about .changes .unit .notes p {
		font-size: 11px;
		font-weight: 400;
		letter-spacing: 0.06em;
		line-height: 1.45em;
		font-feature-settings: "palt";
		text-align: center;
		margin-top: 1em;
	}
	
	#about .reason {
		padding-bottom: 70px;
	}
	#about .reason::before {
		height: 250px;
	}
	#about .reason .inner {
		width: 100%;
		overflow: hidden;
	}
	#about .reason .i {
		width: 100%;
		height: 250px;
		margin-bottom: 55px;
	}
	#about .reason .cont {
		display: block;
		padding-left: 0;
	}
	#about .reason .cont h3 {
		font-size: 18px;
		letter-spacing: 0.14em;
		line-height: 1.66em;
		text-align: center;		
		margin: 0 0 25px;
	}
	#about .reason .cont h3 img {
		width: 95px;
		margin: 20px auto 0;
	}
	#about .reason .cont .text {
		width: 100%;
		padding: 0 25px;
	}
	#about .reason .cont .text p {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 2em;
		margin-bottom: 2em;
	}
	
	#about .founder {
		width: 100%;
		padding: 75px 34px 60px;
	}
	#about .founder h3 {
		position: static;
		left: auto;
		top: auto;
		transform: rotate(0deg) translate(0, 0);		
		text-align: center;
	}
	#about .founder .unit {
		display: block;
		padding: 30px 0 0;
		margin-bottom: 0;
	}
	#about .founder div.unit:nth-of-type(2) {
		padding-top: 60px;
	}
	#about .founder .unit .i {
		width: 207px;
		margin: 0 auto 0;
	}
	#about .founder .unit .cont {
		width: 100%;
		padding-top: 20px;
	}
	#about .founder .unit .cont h4 {
		font-size: 19px;
		letter-spacing: 0.12em;
		text-align: center;
		margin-bottom: 1em;
	}
	#about .founder .unit .cont h4 span {
		display: block;
		font-size: 12px;
		line-height: 1em;
		margin-left: 0;
		margin: 1em 0 0;
	}
	#about .founder .unit .cont p:first-of-type {
		font-size: 13px;
		line-height: 1.69em;
		text-align: center;
		margin-bottom: 40px;
	}
	#about .founder .unit .cont p:first-of-type::after {
		left: calc(50% - 50px);
		bottom: -20px;
		width: 100px;
	}
	#about .founder .unit .cont p:last-of-type {
		font-size: 14px;
		line-height: 1.857em;
	}

	#about .banner h3 {
		margin-bottom: 30px;
	}
	#about .banner a {
		display: block;
		width: 100%;
		height: 280px;
		padding: 0 25px;
		margin: auto;
	}
	
	
	/*===== Studio =====*/
	#studio .f_list img.ii01,
	#studio .f_list img.ii02,
	#studio .f_list img.ii03 {
		animation: fluffy_sp 3s infinite;
	}
	#studio .f_list img.ii01 {
		left: auto;
		right: 15px;
		bottom: auto;
		top: -35px;
		width: 68px;	
	}
	#studio .f_list img.ii02 {
		left: 7px;
		right: auto;
		top: 145px;
		bottom: auto;
		width: 54px;
		animation-delay: 1.2s;
	}
	#studio .f_list img.ii03 {		
		left: auto;
		right: 80px;
		bottom: -80px;
		width: 68px;
		animation-delay: 2.4s;
	}
	
	
	#studio .img_box {
		position: relative;
		padding: 50px 0 175px;
	}
	#studio .img_box img.i01_sp {
		display: block;
		position: absolute;
		left: 0;
		top: 78px;
		width: 160px;
		height: 150px;
	}
	#studio .img_box img.i02_sp {
		display: block;
		width: 170px;
		height: 250px;
		margin: 0 0 0 auto;
	}
	#studio .img_box img.i03_sp {
		display: block;
		position: absolute;
		left: 25px;
		top: 266px;
		width: 150px;
		height: 107px;
	}
	
	#studio .lp {
		overflow: hidden;
	}

	#studio .lp h3 {
		margin-bottom: 30px;
	}
	
	#studio .lp #l01,
	#studio .lp #l02 {
		padding: 80px 0 50px;
	}
	#studio .lp #l01 .cover,
	#studio .lp #l02 .cover {
		height: 40px;
	}
	#studio .lp #l01 .cover::before,
	#studio .lp #l02 .cover::before {
		width: 893px;
		height: 40px;	
		clip-path: url(#cpath1_sp);
	}
	
	#studio .lp .box {
		display: block;
		width: 100%;
		overflow: hidden;
	}
	#studio .lp .box .h h4 {
		text-align: center;
		margin-bottom: 40px;
	}
	#studio .lp .box .h h4 span:nth-of-type(1) {
		font-size: 28px;
		letter-spacing: 0.18em;
	}
	#studio .lp .box .h h4 span:nth-of-type(2) {
		font-size: 21px;;
		line-height: 1em;
		margin-top: 0.5em;
	}
	#studio .lp .box .h h4 span:nth-of-type(2) br {
		display: none;
	}
	#studio .lp .box .h h4 span:nth-of-type(3) {
		font-size: 13px;
		letter-spacing: 0.15em;
		margin-top: 1em;
	}

	#studio .lp .box .cont {
		width: 100%;
	}
	#studio .lp .box .cont .i {
		width: 100%;
		height: 275px;
		margin-bottom: 40px;
	}
	#studio .lp .box .cont h5 {
		font-size: 19px;
		padding-bottom: 14px;
		margin-bottom: 20px;
	}
	#studio .lp .box .cont p {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.857em;
		max-width: 100%
	}
	#studio .lp .box .cont p.s {
		font-size: 13px;
		line-height: 1.769em;
		margin-top: 1em;
	}
	#studio .lp .box .cont a.btn {
		display: block;
		font-feature-settings: "palt";
		width: 320px;
		margin: 35px auto 0;
	}

	#studio .lp .box .cont .text {
		padding: 0 25px;
	}
	#studio .lp .box .cont .text .lt {
		position: relative;
		right: auto;
		top: auto;
		z-index: 10;
		text-align: center;
		width: 100%;
		margin: 42px 0 -35px;
		border-left: none;
	}
	#studio .lp .box .cont .text .lt > span {
		font-size: 13px;
		margin-top: 0;
	}
	#studio .lp .box .cont .text .lt > div {
		font-size: 24.25px;	
		width: 75px;
		height: 75px;
		padding-top: 18px;
		margin: 13px auto 0;
	}
	#studio .lp .box .cont .text .lt > div span {
		font-size: 13.2px;
	}

	#studio .lp .box .cont .text .i2 {
		position: static;
		left: auto;
		top: auto;
		width: 215px;
		height: 288px;
		margin: auto;
	}
	#studio .lp .l02 .box .cont .text .i2 {
		top: auto;
	}
	
	#studio .other_price {
		padding: 70px 20px 75px;
	}
	#studio .other_price .hyo {
		width: 100%;
	}
	
	#studio .other_price img.ii04,
	#studio .other_price img.ii05,
	#studio .other_price img.ii06 {
		animation: fluffy_sp 3s infinite;
	}
	#studio .other_price img.ii04 {
		left: -6px;
		bottom: -32px;
		width: 47px;	
	}
	#studio .other_price img.ii05 {		
		left: 44px;
		bottom: -124px;
		width: 65px;
		animation-delay: 1.2s;
	}
	#studio .other_price img.ii06 {		
		left: 252px;
		bottom: -92px;
		width: 34px;
		animation-delay: 2.4s;
	}
	
	#studio .founder .slide {
		position: relative;
		height: 400px;
		margin-bottom: 42px;
	}
	
	#studio .founder .slide .tgt {
		display: flex;
		flex-wrap: wrap;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		position: absolute;
		right: -8px;
		bottom: -30px;
		z-index: 1000;
		color: var(--bk3);
		font-size: 13px;
		font-weight: 700;
		letter-spacing: 0.12em;
		line-height: 1.45em;
		text-align: center;
		width: 100px;
		height: 92px;
		background: url("../img/target_back.png") no-repeat 0 0 / 100px 92px;
	}
	#studio .founder .slide .tgt span {
		display: block;
		font-size: 12px;
		line-height: 1em;
		width: 40px;
		padding: 5px 0 9px;
		margin: 0 auto 7px;
		background-image: radial-gradient(circle, var(--bk3) 1px, transparent 1px);
		background-position: left bottom;
		background-repeat: repeat-x;
		background-size: 4px 2px;
	}

	#studio .founder .plan_wrap .plan {
		color: #fff;
		padding: 70px 25px 50px;
		background-color: var(--back4);
		transition: all .5s;
	}
	#studio .founder .plan_wrap.bk .plan {
		color: var(--key);
		background-color: var(--bakc5);
	}
	#studio .founder .plan_wrap .plan h3 {
		font-size: 13px;
		font-weight: 700;
		letter-spacing: 0.18em;
		line-height: 1em;
		text-align: center;
		margin-bottom: 45px;
	}
	#studio .founder .plan_wrap .plan h3 span {
		display: inline-block;
		font-size: 19px;
		letter-spacing: 0.14em;
		line-height: 1em;
		padding: 10px 15px;
		margin-top: 15px;
		border: 1px solid #fff;
		border-radius: 7px;
	}
	#studio .founder .plan_wrap .plan h4 {		
		display: inline-block;
		font-size: 19px;
		font-weight: 700;
		letter-spacing: 0.14em;
		line-height: 1em;
		text-decoration: underline;
		text-decoration-thickness: 1px;
		text-underline-offset: 9px;
		margin-bottom: 30px;
	}
	#studio .founder .plan_wrap .plan p {
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 1.857em;
		margin-bottom: 1.857em;
		font-feature-settings: "palt";
	}
	#studio .founder .plan_wrap .plan p:first-of-type {
		font-size: 17px;
		letter-spacing: 0.18em;
		line-height: 1.647em;
		margin-bottom: 1.4em;
	}
	#studio .founder .plan_wrap .plan h5 {		
		color: #fff;
		font-size: 19px;
		font-weight: 700;
		letter-spacing: 0.14em;
		line-height: 1em;
		text-align: center;
		height: 50px;
		padding: 15px 0 0; 
		background-color: var(--key);
		border-radius: 5px;
		margin: 50px 0 0;
	}
	#studio .founder .plan_wrap .plan table {
		width: 100%;
	}
	#studio .founder .plan_wrap .plan td {
		font-size: 16px;
		font-weight: 700;
		letter-spacing: 0.12em;
		line-height: 1.75em;
		vertical-align: center;
		height: 70px;
		border-bottom: 1px solid #fff;
	}
	#studio .founder .plan_wrap.bk .plan td {
		border-bottom-color: var(--key);
	}
	#studio .founder .plan_wrap .plan tr td:last-of-type {
		text-align: right;
	}
	#studio .founder .plan_wrap .plan tr:last-of-type td {
		border-bottom: none;
	}
	
	#studio_list {
		padding: 75px 0 55px;
	}
	#studio_list > div {
		display: block;
		width: 100%;
		margin: 0;
	}
	#studio_list > div h3 {
		text-align: center;
		width: 100%;
		margin-bottom: 45px;
	}
	
	#studio_list .studio > ul {
		width: 100%;
		padding: 0 25px;
	}
	#studio_list .studio > ul > li {
		display: block;
		margin-bottom: 70px;
	}
	#studio_list .studio > ul > li > div:first-of-type {
		width: 100%;
	}
	#studio_list .studio > ul > li > div:last-of-type {
		width: 100%;
	}

	#studio_list .studio h4 {
		font-size: 19px;
		margin-bottom: 20px;
	}
	#studio_list .studio h4::after {
		width: 190px;
	}
	#studio_list .studio ul > li:nth-of-type(2) h4::after {
		width: 170px;
	}
	#studio_list .studio p,
	#studio_list .studio p + ul li {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.714em;
	}
	#studio_list .studio p + ul {
		margin: 15px 0;
	}

	#studio_list .studio table td {
		font-size: 12px;
		padding: 10px 8px;
	}

	#studio_list .studio iframe {
		display: block;
		width: 100%;
		height: 225px;
		margin-top: 35px;
	}
	#studio_list .studio a.btn {
		display: block;
		font-feature-settings: "palt";
		width: calc(100% - 10px);
		padding-left: 48px;
		margin: 37px auto 0;
	}
	#studio_list .studio a.btn::before {
		left: 15px;
		top: 50%;
		width: 22px;
		height: 23px;
		background: url("../img/calender.png") no-repeat 0 0 / 22px 23px;
	}
	
	#studio_list .banner ul {
		display: block;
		width: 270px;
		margin: auto;
	}
	#studio_list .banner ul li {
		width: 100%;
		margin: 0 0 20px;
	}
	#studio_list .banner ul li a {
		height: 82px;
	}
	
	
	
	/*===== Online =====*/
	#online .f_list img.ii01,
	#online .f_list img.ii02,
	#online .f_list img.ii03 {
		animation: fluffy_sp 3s infinite;
	}
	#online .f_list img.ii01 {
		left: 11px;
		bottom: 700px;
		width: 65px;	
	}
	#online .f_list img.ii02 {		
		right: 6px;
		bottom: 350px;
		width: 68px;
		animation-delay: 1.2s;
	}
	#online .f_list img.ii03 {		
		left: 22px;
		bottom: -60px;
		width: 66px;
		animation-delay: 2.4s;
	}
	
	#online .img_box {
		position: relative;
		padding: 55px 0 85px;
	}
	#online .img_box img.i01_sp {
		display: block;
		position: absolute;
		left: 25px;
		top: 88px;
		width: 157px;
		height: 112px;
	}
	#online .img_box img.i02_sp {
		display: block;
		width: 170px;
		height: 250px;
		margin: 0 0 0 auto;
	}
	#online .img_box img.i03_sp {
		display: block;
		position: absolute;
		left: 70px;
		top: 187px;
		width: 165px;
		height: 145px;
	}

	#online .fp {
		padding: 85px 0 75px;
	}
	#online .fp .cover {
		height: 40px;
	}
	#online .fp .cover::before {
		width: 893px;
		height: 40px;
		clip-path: url(#cpath1_sp);
	}
	
	#online .fp h4 {
		color: var(--key);
		font-size: 14px;
		font-weight: 700;
		letter-spacing: 0.18em;
		line-height: 1em;
		text-align: center;
		margin: 45px 0 0;
	}
	#online .fp h4 span {
		display: block;
		font-size: 19px;
		letter-spacing: 0.14em;
		line-height: 1em;
		width: 150px;
		height: 40px;
		padding-top: 9px;
		margin: 15px auto 0;
		border: 1px solid var(--key);
		border-radius: 13px;
	}
	
	#online .fp .slide {
		position: relative;
		padding: 50px 0 0 25px;
	}
	#online .fp .slide .swiper-wrapper {
		justify-content: space-between;
		align-items: stretch !important;	
	}
	#online .fp .slide .swiper-slide {
		text-align: center;
		width: 235px;
		height: 400px !important;
		overflow: visible;
		padding: 35px 15px 0;
		margin-right: 25px;
		background-color: #fff;
		border-radius: 14px;
	}
	
	#online .fp .slide .b_lfp {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		left: 25px;
		bottom: -25px;
		width: calc(100vw - 50px);
	}
	#online .fp .slide .b_lfp .swiper-pagination-bullet {
		display: block;
		width: calc((100vw - 50px - 20px) / 5);
		height: 2px;
		border-radius: 0;
		background-color: #fff;
		opacity: 1;
	}
	#online .fp .slide .b_lfp .swiper-pagination-bullet-active {
		background-color: var(--key);
	}
	
	#online .fp .slide .swiper-slide .no {
		color: var(--key);
		font-size: 24.3px;
		font-weight: 700;
		letter-spacing: 0.11em;
		line-height: 1em;
		margin-bottom: 25px;
		text-decoration: underline;
		text-decoration-thickness: 1.5px;
		text-underline-offset: 7px;
	}
	#online .fp .slide .swiper-slide .illust {
		margin-bottom: 25px;
	}
	#online .fp .slide .swiper-slide .illust img {
		width: auto;
		height: 115px;
	}
	#online .fp .slide .swiper-slide .title {
		display: flex;
		align-items: center;
		justify-content: center;
		position: relative;
		color: var(--key);
		font-size: 16px;
		font-weight: 700;
		letter-spacing: 0.14em;
		line-height: 1.51em;
		height: 50px;
		margin-bottom: 35px;
	}
	#online .fp .slide .swiper-slide .title::after {
		content: "";
		display: block;
		position: absolute;
		left: calc(50% - 40px);
		bottom: -17px;
		width: 80px;
		height: 1px;
		background-color: var(--gy3);
	}
	#online .fp .slide .swiper-slide .text p {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.54em;
		font-feature-settings: "palt";
	}

	#online .fp .price {
		width: 100%;
		padding: 0 25px;
		margin: 75px auto 0;
	}
	#online .fp .price h3 {
		margin-bottom: 38px;
	}
	
	#online .fp img.ii04,
	#online .fp img.ii05,
	#online .fp img.ii06 {
		animation: fluffy_sp 3s infinite;
	}
	#online .fp img.ii04 {
		right: 220px;
		bottom: -90px;
		width: 34px;	
	}
	#online .fp img.ii05 {		
		right: 15px;
		bottom: -122px;
		width: 67px;
		animation-delay: 2.4s;
	}
	#online .fp img.ii06 {		
		right: 100px;
		bottom: -27px;
		width: 47px;
		animation-delay: 1.2s;
	}
	
	
	
	/*===== Q&A =====*/
	#qa {
		padding: 0 0 40px;
	}

	#qa .cont {
		width: 100%;
		padding: 20px 25px 0;
	}
	#qa .cont dl {
		position: relative;
		border-radius: 11px;
		cursor: pointer;
		pointer-events: auto;
	}
	#qa .cont dl::after {
		content: "";
		display: block;
		position: absolute;
		right: 20px;
		bottom: -15px;
		width: 30px;
		height: 30px;
		background: url("../img/qa_arrow_sp.png") no-repeat 0 0 / 30px 30px;
		transform: rotate(0deg);
		transition: all .3s;
	}
	#qa .cont dl.open::after {
		transform: rotate(180deg);
	}
	#qa .cont dl.qa dt div {
		font-size: 15px;
		letter-spacing: 0.07em;
		line-height: 1.5em;
		padding: 20px 20px 20px 58px;
	}
	#qa .cont dl.qa dt div::before {
		left: 10px;
		top: 15px;
		transform: translate(0,0);
		width: 36px;
		height: 33px;
		background: url("../img/Q_sp.png") no-repeat 0 0 / 36px 33px;
	}
	#qa .cont dl.qa dt div::after {
		display: none;
	}
	#qa .cont dl.qa dd div {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.857em;
		padding: 20px 20px 20px 58px;
	}
	#qa .cont dl.qa dd div::before {
		left: 56px;
		width: calc(100% - 80px);
		height: 2px;
		background-image: radial-gradient(circle, var(--key) 1px, transparent 1px);
		background-position: left top;
		background-repeat: repeat-x;
		background-size: 6px 2px;
	}
	
	
	/*===== News & Column =====*/
	#news_list {
		padding-bottom: 70px;
	}
	#news_list .page_h {
		padding-bottom: 10px;
	}

	.category_list {
		width: 100%;
		padding: 0 25px;
		margin: 0 auto 45px;
	}
	.category_list > div {
		justify-content: flex-start;	
	}
	.category_list > div h3 {
		color: var(--key);
		font-size: 11.5px;
		width: 100%;
		padding: 0 0 15px;
		border: none;
	}
	.category_list > div ul {
		padding-bottom: 0;
	}
	.category_list > div ul li {
		font-size: 14px;
		letter-spacing: 0.07em;
		margin-bottom: 10px;
	}
	.category_list > div ul li::after {
		margin: 0 4px;
	}

	.post_list {
		width: 100%;
		padding: 0 25px;
		margin: auto;
	}
	.post_list ul {
		justify-content: space-between;
	}
	.post_list ul li {
		width: calc((100% - 27px) / 2);
		margin: 0 0 35px;
	}
	.post_list ul li a {
		display: block;
	}
	.post_list ul li .i {
		height: 100px;
		margin-bottom: 20px;
	}
	.post_list ul li .sub {		
		font-size: 10px;
		margin-bottom: 10px;
	}
	.post_list ul li .sub .date::after {
		margin: 0 5px;
	}
	.post_list ul li .title {
		overflow: hidden;
		display: -webkit-box;
		text-overflow: ellipsis;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 3;
	}
	.post_list ul li .title p {
		font-size: 14px;
		letter-spacing: 0.1em;
		line-height: 1.54em;
		text-align: left;
	}
	
	.pagenavi span,
	.pagenavi a {
		font-size: 14px;
		margin: 0 6px !important;
	}
	
	
	/*===== Single =====*/
	#single {
		padding: 87.5px 25px 90px;
	}
	#single article {
		width: 100%;
		padding: 45px 20px 37.5px;
		border-radius: 15px;
	}
	
	#single .h {
		padding: 18px 0 14px;
		margin-bottom: 30px;
	}
	#single .h .sub {
		top: -8px;
		font-size: 10px;
		height: 16.5px;
		padding: 2px 8px 0;
		border-radius: 8px;
	}
	#single .h .sub::after {
		right: -11px;
		width: 10px;
	}
	#single .h .sub .date::after {
		content: "|";
		display: inline-block;
		margin: 0 5px;
	}
	#single .h h2 {
		font-size: 16px;
		letter-spacing: 0.07em;
		line-height: 1.625em;
	}
	
	#single .cont p {
		font-size: 14px;
		letter-spacing: 0.07em;
		line-height: 1.857em;
		margin-bottom: 1.857em;
	}
	#single .cont h2 {
		font-size: 16px;
		line-height: 1.59em;
		padding: 8px 15px;
		margin: 42px 0 25px;
		border-radius: 7.5px;
	}
	#single .cont .wp-block-image {
		margin: 25px 0;
	}
	
	.pager {
		width: 234px;
		margin: 25px auto 0;
	}
	.pager td a img {
		width: 15px;
	}
	.pager tr td:nth-of-type(2) a {
		font-size: 14px;
		letter-spacing: 0.07em;
		width: 130px;
		height: 40px;
		padding-top: 13px;
	}
	
	
	/*===== Professional single =====*/
	#professional_single {
		padding: 0 0 70px;
	}
	#professional_single .page_h {
		padding-bottom: 0px;
	}
	#professional_single .page_h h2 {
		margin-bottom: 30px;
	}

	#professional_single article {
		display: block;
		width: calc(100% - 50px);
		padding: 35px 18px;
		margin: auto;
		border-radius: 10px;
	}

	#professional_single article .h {
		text-align: center;
		width: 100%;
		margin-bottom: 35px;
	}
	#professional_single article .h .i {
		width: 210px;
		height: 230px;
		margin: 0 auto 20px;
	}
	#professional_single article .h .title {
		font-size: 11px;
		line-height: 1.4em;
		margin-bottom: 0.5em;
	}
	#professional_single article .h h3.name {
		font-size: 17.5px;
	}
	#professional_single article .h h3.name span {
		font-size: 13px;
		margin-left: 0.5em;
	}
	#professional_single article .h .en {
		color: var(--key);
		font-size: 10.5px;
		margin-top: 0.5em;
	}

	#professional_single article .cont {
		width: 100%;
	}
	#professional_single article .cont h3 {
		font-size: 15px;
		margin-bottom: 1.2em;
	}
	#professional_single article .cont h3::after {
		width: 195px;
	}
	#professional_single article .cont p + h3 {
		margin-top: 2em;
	}
	#professional_single article .cont p {
		font-size: 14px;
		line-height: 2em;	
		margin-bottom: 1em;
	}
	#professional_single article .cont p:last-of-type {
		font-size: 13px;
		line-height: 1.84em;
	}
	
	#professional_single article .banner {
		margin-top: 30px;
	}
	#professional_single article .banner h3 {
		font-size: 15px;
		font-weight: 500;
		letter-spacing: 0.15em;
		line-height: 1em;
		margin-bottom: 1em;
	}
	#professional_single article .banner a {
		display: block;
		width: 100%;
		height: 88px;
	}
	
	.pager2 {
		width: calc(100% - 50px);
		margin: 30px auto 0;
	}
	.pager2 td {
		width: 40%;
	}
	.pager2 tr td:nth-of-type(2) {
		width: 20%;
	}
	.pager2 td a {
		font-size: 14px;
	}
	.pager2 td a img {
		width: 27px;
		height: 27px;
	}
	
	
	/*===== Contact =====*/
	#contact {
    width: 100%;
    padding: 0 0 60px;
  }
	
	#contact .page_h img.i01,
	#contact .page_h img.i02 {
		
	}
	#contact .page_h img.i01 {		
		right: 23px;
		bottom: -22px;
		width: 70px;
		animation: fluffy_sp 3s infinite;
	}
	#contact .page_h img.i02 {
		left: 22px;
		top: -14px;
		width: 47px;
		animation: fluffy_sp2 3s infinite;
	}
	
	#contact .inq {
		width: 100%;
		padding: 0 25px;
	}

	#contact table,
	#contact table tbody,
	#contact table tr,
	#contact table td {
		display: block;
		width: 100% !important;
	}
	
	
	#contact .inq p.last {
    font-size: 13px;
		letter-spacing: 0.07em;
    line-height: 1.76em;
    margin-top: 25px;
  }
  
  #contact td p {
    font-size: 14px;
		letter-spacing: 0.07em;
  }
  #contact tr td:nth-of-type(1) {
    padding: 0 0 10px 1em;
  }
  #contact tr td:nth-of-type(2) {  
    padding-bottom: 30px;
  }
	
  #contact tr td:nth-of-type(2) div {
    min-height: 55px;
    padding: 19px 10px;
		border-radius: 9px;
  }

	/*---- check leyout -----*/
	#contact tr td:nth-of-type(2) div.ck {
		padding: 25px 20px 10px 20px;
	}
	#contact tr td:nth-of-type(2) div.ck .wpcf7-form-control .wpcf7-list-item {
		width: 100%;
		margin-bottom: 15px;
	}

	/*---- 送信確認 -----*/
  #contact tr.flex {
		display: block !important;
  }
	#contact .ac {		
		padding: 1em 0 0 !important;
	}
	#contact .ac .a {
		display: inline-block;
		font-size: 12px;
		letter-spacing: 0.04em;
		margin-top: 0.8em;
	}
  
	/*----- item -----*/
  input[type="text"],
  input[type="email"],
  textarea {
    font-size: 16px;
  }
  textarea {
    height: 310px;
  }

  /*----- その他テキスト -----*/
	.wpcf7-list-item.has-free-text input {
		width: 180px;
		margin-left: 0;
	}

	/*----- lable -----*/
  .inq label {
    font-size: 14px;
    letter-spacing: 0.07em;
    padding-left: 24px;
  }
  .inq .wpcf7-list-item-label {
    display: inline-block;
    font-size: 14px;
    letter-spacing: 0.07em;
  }
  .inq label::before {
    content: "";
    display: inline-block;
    position: absolute;
    left: 0;
    top: 1px;
    width: 15px;
    height: 15px;
  }
  .inq label input[type="radio"]:checked + .wpcf7-list-item-label::before,
  .inq label input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
    content: "";
    display: inline-block;
    position: absolute;
    left: 0;
    top: 1px;
    width: 15px;
    height: 15px;
    box-sizing: border-box;
  }
	
	/*----- submit ------*/
  #contact .btn {
    width: 208px;
    margin: 5px auto 0;
  }
  #contact .btn p {
    height: 40px;
    overflow: hidden;
  }
  .wpcf7-submit {
    font-size: 14px;
    line-height: 1em;
    letter-spacing: 0.07em;
    height: 40px;
    border-radius: 20px;
  }
  
	/*----- 送信後 ------*/
  .transmission {
		padding: 114px 0 90px;
  }
	.transmission p {
		font-size: 13px !important;
	}
	
	/*----- エラー ------*/
	.wpcf7-not-valid-tip {
		display: block !important;
		bottom: -30px;
		font-size: 12px !important;
	}
	.ck .wpcf7-not-valid-tip {
		left: -20px;
		bottom: -25px;
		width: 250px; /* iOS用 幅をpxで明示しないと幅が0になるため */
	}
	textarea + .wpcf7-not-valid-tip {
		bottom: -30px;
	}
	
	
	/*----- reCAPTCHA ------*/
	.reCAPTCHA_text p {
		font-size: 11px;
		letter-spacing: 0.08em;
		line-height: 1.47em;
		text-align: center;
		margin-top: 25px;
	}
	
	
	/*===== Not found =====*/
	#not-found .flex {
		padding: 200px 0 150px;
	}
	#not-found .flex p {
		font-size: 13px;
		letter-spacing: 0.08em;
		line-height: 1.6em;
	}
  
}


@keyframes circlemove_sp {
  0% {bottom: 88px;}
  100% {bottom: -5px;}
}

@keyframes fluffy_sp {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-5px);
  }
}

@keyframes fluffy_sp2 {
  0%, 100% {
    transform: translateY(0) rotate(90deg);
  }
  50% {
    transform: translateY(-5px) rotate(90deg);
  }
}

@keyframes mae {
  0% {
		opacity: 0;
  }
  100% {
		opacity: 1;
  }
}
@keyframes ato {
  0% {
		opacity: 0;
  }
  100% {
		opacity: 1;
  }
}