@charset "UTF-8";
/* CSS Document */
html {
	font-size:62.5%;
}
body {
	font-family:'Noto Sans JP',Arial,sans-serif;
	line-height:1.8;
    font-weight: 400;
	color: #333;
}
a,
a:active,
a:visited {
	text-decoration:none;
	color:#000;
}
a:hover {
	filter: alpha(opacity=60);
	-moz-opacity:0.60;
	opacity:0.60;
}
a,
a:hover {
	-webkit-transition: 0.3s;
	-moz-transition: 0.3s;
	-o-transition: 0.3s;
	transition: 0.3s;
}
img {
	max-width:100%;
	height: auto;
    vertical-align: bottom;
}
img.vab {
	vertical-align:baseline;
}
img.vam {
	vertical-align: middle;
}
.js-form-global-error,
[data-error-for] {
	color: #e60012;
}

/* Thanks page
-------------------------------------------------------*/
.thanksWrap {
	padding: 15px 0 30px;
}
.thanksHeader {
	background-color: #ff9db1;
	border-radius: 8px;
	padding: 10px 12px;
	text-align: center;
	color: #fff;
}
.thanksMessage {
	margin: 15px 0 20px;
	line-height: 1.7;
}
.thanksMessage p + p {
	margin-top: 8px;
}
.thanksStepsTitle {
	border-left: 4px solid #ff859e;
	padding-left: 10px;
	margin-bottom: 10px;
	color: #333;
}
.thanksStep {
	border: 1px solid #f3cbd4;
	border-radius: 12px;
	padding: 15px;
	margin-top: 15px;
	text-align: center;
	background-color: #fff;
}
.thanksStepLabel {
	display: inline-block;
	background-color: #ff9db1;
	color: #fff;
	border-radius: 999px;
	padding: 4px 14px;
	margin-bottom: 8px;
}
.thanksStepTitle {
	color: #ff859e;
	margin-bottom: 6px;
}
.thanksStepBody {
	line-height: 1.6;
}
.thanksLink {
	display: inline-block;
	background-color: #ff859e;
	color: #fff;
	padding: 10px 26px;
	border-radius: 30px;
}
.thanksLink:hover,
.thanksLink:visited {
	color: #fff;
}
.pr {
	position:relative;
}
.tac {
	text-align:center;
}
.tacPc {
	text-align:center;
}
.tar {
	text-align:right;
}
.tal {
	text-align:left;
}
.contBox {
	width: 90%;
	max-width: 1000px;
	margin:0 auto;
}
.contBox100 {
	width: 100%;
}
.mgnAuto {
	margin: auto;
}
.mb5 {
	margin-bottom:5px !important;
}
.mb10 {
	margin-bottom:10px !important;
}
.mb15 {
	margin-bottom:15px !important;
}
.mb20 {
	margin-bottom:20px !important;
}
.mb30 {
	margin-bottom:30px !important;
}
.mb40 {
	margin-bottom:40px !important;
}
.mb50 {
	margin-bottom:50px !important;
}
.mb60 {
	margin-bottom:60px !important;
}
.mb70 {
	margin-bottom:70px !important;
}
.mb80 {
	margin-bottom:80px !important;
}
.mb90 {
	margin-bottom:90px !important;
}
.mb100 {
	margin-bottom:100px !important;
}
.mt5 {
	margin-top:5px !important;
}
.mt10 {
	margin-top:10px !important;
}
.mt15 {
	margin-top:15px !important;
}
.mt20 {
	margin-top:20px !important;
}
.mt30 {
	margin-top:30px !important;
}
.mt40 {
	margin-top:40px !important;
}
.mt50 {
	margin-top:50px !important;
}
.mt60 {
	margin-top:60px !important;
}
.mt70 {
	margin-top:70px !important;
}
.mt80 {
	margin-top:80px !important;
}
.mt90 {
	margin-top:90px !important;
}
.mt100 {
	margin-top:100px !important;
}
.pcCont {
	display:block !important;
}
.pcTabCont {
	display:block !important;
}
.tabOnlyCont {
	display:none !important;
}
.spCont {
	display:none !important;
}
.spOnlyCont {
	display:none !important;
}
.fwb {
    font-weight: bold !important;
}
.fw500 {
    font-weight: 500 !important;
}
.fw600 {
    font-weight: 600 !important;
}
.fw700 {
    font-weight: 700 !important;
}
.fw900 {
    font-weight: 900 !important;
}
.ls01 {
    letter-spacing: 0.1em;
}
.ls02 {
    letter-spacing: 0.075em;
}
.ls03 {
    letter-spacing: 0.05em;
}
.ls04 {
    letter-spacing: 0.025em;
}
.ls05 {
    letter-spacing: 0.2em;
}
.ls06 {
    letter-spacing: -0.05em;
}
.ls07 {
    letter-spacing: -0.2em;
}
.ls08 {
    letter-spacing: -0.025em;
}
.lh13 {
    line-height: 1.3;
}
.lh14 {
    line-height: 1.4;
}
.lh15 {
    line-height: 1.5;
}
.lh16 {
    line-height: 1.6;
}
@media screen and (max-width: 900px) {
    a:hover {
        filter: alpha(opacity=100);
        -moz-opacity:1;
        opacity:1;
    }
    .pcCont {
        display:none !important;
    }
    .tabOnlyCont {
        display:block !important;
    }
    .spCont {
        display:block !important;
    }
    .tacTab {
        text-align: center;
    }
    .tacPc {
        text-align: left;
    }
}
@media screen and (max-width: 600px) {
    body {
        font-size: 1.5rem;
    }
    .spOnlyCont {
        display:block !important;
    }
    .pcTabCont {
        display:none !important;
    }
    .tabOnlyCont {
        display:none !important;
    }
    .tacSp {
        text-align: center;
    }
    .mb10 {
        margin-bottom:10px !important;
    }
    .mb15 {
        margin-bottom:15px !important;
    } 
    .mb20 {
        margin-bottom:20px !important;
    }
    .mb30 {
        margin-bottom:30px !important;
    }
    .mb40 {
        margin-bottom:30px !important;
    }
    .mb50 {
        margin-bottom:30px !important;
    }
    .mb60 {
        margin-bottom:30px !important;
    }
    .mb70 {
        margin-bottom:40px !important;
    }
    .mb80 {
        margin-bottom:60px !important;
    }
    .mb90 {
        margin-bottom:60px !important;
    }
    .mb100 {
        margin-bottom:60px !important;
    }
    .mt5 {
        margin-top:5px !important;
    }
    .mt10 {
        margin-top:10px !important;
    }
    .mt15 {
        margin-top:10px !important;
    }
    .mt20 {
        margin-top:20px !important;
    }
    .mt30 {
        margin-top:20px !important;
    }
    .mt40 {
        margin-top:20px !important;
    }
    .mt50 {
        margin-top:30px !important;
    }
    .mt60 {
        margin-top:30px !important;
    }
    .mt70 {
        margin-top:40px !important;
    }
    .mt80 {
        margin-top:60px !important;
    }
    .mt90 {
        margin-top:60px !important;
    }
    .mt100 {
        margin-top:60px !important;
    }
}
.f9 {
    font-size: calc(100vw * 9 / 400) !important;
}
.f10 {
    font-size: calc(100vw * 10 / 400) !important;
}
.f11 {
    font-size: calc(100vw * 11 / 400) !important;
}
.f12 {
    font-size: calc(100vw * 12 / 400) !important;
}
.f13 {
    font-size: calc(100vw * 13 / 400) !important;
}
.f14 {
    font-size: calc(100vw * 14 / 400) !important;
}
.f15 {
    font-size: calc(100vw * 15 / 400) !important;
}
.f155 {
    font-size: calc(100vw * 15.5 / 400) !important;
}
.f16 {
    font-size: calc(100vw * 16 / 400) !important;
}
.f17 {
    font-size: calc(100vw * 17 / 400) !important;
}
.f18 {
    font-size: calc(100vw * 18 / 400) !important;
}
.f19 {
    font-size: calc(100vw * 19 / 400) !important;
}
.f20 {
    font-size: calc(100vw * 20 / 400) !important;
}
.f21 {
    font-size: calc(100vw * 21 / 400) !important;
}
.f22 {
    font-size: calc(100vw * 22 / 400) !important;
}
.f23 {
    font-size: calc(100vw * 23 / 400) !important;
}
.f24 {
    font-size: calc(100vw * 24 / 400) !important;
}
.f25 {
    font-size: calc(100vw * 25 / 400) !important;
}
.f26 {
    font-size: calc(100vw * 26 / 400) !important;
}
.f27 {
    font-size: calc(100vw * 27 / 400) !important;
}
.f28 {
    font-size: calc(100vw * 28 / 400) !important;
}
.f30 {
    font-size: calc(100vw * 30 / 400) !important;
}
.f32 {
    font-size: calc(100vw * 32 / 400) !important;
}
.f34 {
    font-size: calc(100vw * 34 / 400) !important;
}
@media screen and (min-width: 600px) {
    .f9 {
        font-size: calc(100vw * 9 / 600) !important;
    }
    .f10 {
        font-size: calc(100vw * 10 / 600) !important;
    }
    .f11 {
        font-size: calc(100vw * 11 / 600) !important;
    }
    .f12 {
        font-size: calc(100vw * 12 / 600) !important;
    }
    .f13 {
        font-size: calc(100vw * 13 / 600) !important;
    }
    .f14 {
        font-size: calc(100vw * 14 / 600) !important;
    }
    .f15 {
        font-size: calc(100vw * 15 / 600) !important;
    }
    .f155 {
        font-size: calc(100vw * 15.5 / 600) !important;
    }
    .f16 {
        font-size: calc(100vw * 16 / 600) !important;
    }
    .f17 {
        font-size: calc(100vw * 17 / 600) !important;
    }
    .f18 {
        font-size: calc(100vw * 18 / 600) !important;
    }
    .f19 {
        font-size: calc(100vw * 19 / 600) !important;
    }
    .f20 {
        font-size: calc(100vw * 20 / 600) !important;
    }
    .f21 {
        font-size: calc(100vw * 21 / 600) !important;
    }
    .f22 {
        font-size: calc(100vw * 22 / 600) !important;
    }
    .f23 {
        font-size: calc(100vw * 23 / 600) !important;
    }
    .f24 {
        font-size: calc(100vw * 24 / 600) !important;
    }
    .f25 {
        font-size: calc(100vw * 25 / 600) !important;
    }
    .f26 {
        font-size: calc(100vw * 26 / 600) !important;
    }
    .f27 {
        font-size: calc(100vw * 27 / 600) !important;
    }
    .f28 {
        font-size: calc(100vw * 28 / 600) !important;
    }
    .f30 {
        font-size: calc(100vw * 30 / 600) !important;
    }
    .f32 {
        font-size: calc(100vw * 32 / 600) !important;
    }
    .f34 {
        font-size: calc(100vw * 34 / 600) !important;
    }
}
@media screen and (min-width: 800px) {
    .f9 {
        font-size: calc(500px * 9 / 450) !important;
    }
    .f10 {
        font-size: calc(500px * 10 / 450) !important;
    }
    .f11 {
        font-size: calc(500px * 11 / 450) !important;
    }
    .f12 {
        font-size: calc(500px * 12 / 450) !important;
    }
    .f13 {
        font-size: calc(500px * 13 / 450) !important;
    }
    .f14 {
        font-size: calc(500px * 14 / 450) !important;
    }
    .f15 {
        font-size: calc(500px * 15 / 450) !important;
    }
    .f155 {
        font-size: calc(500px * 15.5 / 450) !important;
    }
    .f16 {
        font-size: calc(500px * 16 / 450) !important;
    }
    .f17 {
        font-size: calc(500px * 17 / 450) !important;
    }
    .f18 {
        font-size: calc(500px * 18 / 450) !important;
    }
    .f19 {
        font-size: calc(500px * 19 / 450) !important;
    }
    .f20 {
        font-size: calc(500px * 20 / 450) !important;
    }
    .f21 {
        font-size: calc(500px * 21 / 450) !important;
    }
    .f22 {
        font-size: calc(500px * 22 / 450) !important;
    }
    .f23 {
        font-size: calc(500px * 23 / 450) !important;
    }
    .f24 {
        font-size: calc(500px * 24 / 450) !important;
    }
    .f25 {
        font-size: calc(500px * 25 / 450) !important;
    }
    .f26 {
        font-size: calc(500px * 26 / 450) !important;
    }
    .f27 {
        font-size: calc(500px * 27 / 450) !important;
    }
    .f28 {
        font-size: calc(500px * 28 / 450) !important;
    }
    .f30 {
        font-size: calc(500px * 30 / 450) !important;
    }
    .f32 {
        font-size: calc(500px * 32 / 450) !important;
    }
    .f34 {
        font-size: calc(500px * 34 / 450) !important;
    }
}
.is_pc {
    display: none;
}
.leftCont {
    display: none;
}
.rightCont {
    overflow: clip;
}
@media screen and (min-width: 800px) {
    .is_sp {
        display: none;
    }
    .is_pc {
        display: block;
    }
    .pcspWrap {
        display: flex;
        justify-content: center;
		gap: 100px;
        background: url("../img/bg_main.jpg") no-repeat;
		background-size: cover;
		background-attachment: fixed;

    }
    .rightCont {
        width: 500px;
        background-color: #fff;
    }
}
@media screen and (min-width: 1000px) {
    .leftCont {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        /*width: calc((100% - 560px) / 2);*/
        width: 360px;
        height: 100vh;
        /*z-index: 1000;*/
        position: sticky;
        top: 0;
        left: 0;
    }
}
/*ヘッダー
-------------------------------------------------------*/
header {
    position: sticky;
    top: 0;
    z-index: 1000;
}
.logoFlex {
    display: flex;
    align-items: center;
    height: 50px;
	background-color: #fff;
}
.logo {
    width: 37.5vw;
	margin-left: 5vw;
	margin-right: 4vw;
}
.h1 {
	line-height: 1.5;
}
.ham-btn {
    display:flex;
    align-items: center;
    height: 60px;
    z-index:151;
    padding: 0 1.75rem;
	margin-left: auto;
}
.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.menu-trigger {
  position: relative;
  width: 26px;
  height: 52px;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 26px;
  height: 2px;
  background-color: #000;
}
.menu-trigger span:nth-of-type(1) {
  top: 18px;
}
.menu-trigger span:nth-of-type(2) {
  top: 26px;
}
.menu-trigger span:nth-of-type(3) {
  top: 34px;
}
.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(8px) rotate(-45deg);
  transform: translateY(8px) rotate(-45deg);
}
.menu-trigger.active span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
  -webkit-transform: translateY(-8px) rotate(45deg);
  transform: translateY(-8px) rotate(45deg);
}
.ham-btn a:hover {
    filter: alpha(opacity=100);
    -moz-opacity: 1.0;
    opacity: 1.0;
}
.nav {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 70px 4vw;
    position: absolute;
    top: 0;
    /*left: 0;*/
    transform: translateX(150%);
    transition: all 0.6s;
    width: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    background-color: #ffe7ec;
    z-index: -1;
    /*font-size: 4vw;*/
    /*font-size: clamp(15px, 4vw, 20px);*/
    /*font-size: calc(100vw * 15 / 400);*/
}
.nav.active {
    top: 0;
    transform: translateX(0%);
}
.uLine {
}
.uLine i {
    padding-right: 1rem;
	color: #ff859e;
}
.nav a {
	display: block;
}
@media screen and (min-width: 800px) {
    .logo {
        width: 185px;
        margin-left: 25px;
        margin-right: 20px;
    }
    .nav {
        padding: 70px 25px;
    }
}
.cWhite {
	color: #fff !important;
}
/*CTA見出し（1分で予約完了〜）
-------------------------------------------------------*/
.ctaHead {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  font-size: calc(100vw * 13 / 400);
  line-height: 1;
}
.ctaHead__label {
  position: relative;
  display: inline-block;
  background-color: #ffb0c6;
  color: #fff;
  font-weight: 700;
  padding: 0.4em;
  border-radius: 4px;
  margin-left: 1.5rem;
  text-align: center;
  white-space: nowrap;
  text-shadow:
    1px 0 0 #ec547b,
    -1px 0 0 #ec547b,
    0 1px 0 #ec547b,
    0 -1px 0 #ec547b;
}
.ctaHead__label::before {
  content: '＼';
  position: absolute;
  left: -1.5rem;
  top: 50%;
  transform: translateY(-50%) rotate(10deg);
  color: #000;
  font-weight: 700;
  -webkit-text-stroke: 0;
  text-shadow: none;
}
.ctaHead__text {
  position: relative;
  display: inline-block;
  color: #000;
  font-weight: 700;
  padding: 0.4em 0.9em 0.4em 0.2em;
  text-align: center;
  white-space: nowrap;
}
.ctaHead__text::after {
  content: '／';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) rotate(-10deg);
  color: #000;
  font-weight: 700;
}
@media screen and (min-width: 600px) {
  .ctaHead {
    font-size: calc(100vw * 13 / 600);
  }
}
@media screen and (min-width: 800px) {
  .ctaHead {
    font-size: calc(500px * 13 / 450);
  }
}
/*CTA
-------------------------------------------------------*/
.ctaMain {
	width: 93%;
	margin: auto;
}
.ttlCam {
	width: 74%;
	margin: auto;
}
.cpData {
	position: absolute;
	color: #fff;
	left: 50%;
	bottom: 0;
	transform: translateX(-50%);
	white-space: nowrap;
}
@media screen and (min-width: 800px) {
	.cpData {
        bottom: 1px;
    }
    .leftCont .cpData.f12 {
        font-size: calc(500px * 10.5 / 450) !important;
    }
    .cpData.f12 {
        font-size: calc(500px * 13 / 450) !important;
    }
}
/*K-twoなら安心と言い切れる理由
-------------------------------------------------------*/
.a2Wrap {
	background: url("../img/bg_a2.jpg") top center no-repeat;
	background-size: cover;
	padding: 0 0 7.5vw;
	margin-top: 10vw;
}
.a22 {
	margin-top: -7vw;
	margin-bottom: 3vw;
}
.a23 {
	width: 94.5%;
	margin: auto;
	margin-top: -3vw;
}
@media screen and (min-width: 800px) {
    .a2Wrap {
        padding: 0 0 50px;
        margin-top: 50px;
    }
    .a22 {
        margin-top: -30px;
		margin-bottom: 15px;
    }
    .a23 {
        margin-top: -15px;
    }
}
/*選ばれる3つのポイント
-------------------------------------------------------*/
.mt2 {
	margin-top: 0.75vw;
}
.a3Wrap {
	background: url("../img/bg_a3.jpg") top center no-repeat;
	background-size: cover;
	padding: 6vw 0 15vw;
}
.a3Wrap.point2{
	padding-bottom: 6vw;
}
.a3pointWrap {
	background-color: #fff;
	border-radius: 15px;
	box-shadow: 0 0 15px rgba(0,0,0,.15);
	margin-top: 10vw;
	padding-bottom: 10vw;
}
.a3pointWrap.point2{
	padding-bottom: 5.5vw;
}
.a32 img {
	margin-top: -8vw;
}
.a3w {
	padding: 0 6%;
}
.a3h3 {
	border-radius: 10px;
}
.a3h3.c1 {
	background-color: #33bdb1;
}
.a3h3.c2 {
	background-color: #8c81d0;
}
.a3h3.c3 {
	background-color: #ff9db1;
}
.a3Wrap .shadow {
	box-shadow: 0 0 5px rgba(0,0,0,.15);
}
.a3dl {
	border-radius: 10px;
	padding: 3vw 4vw;
	line-height: 1.5;
}
.a3dl.c1 {
	background-color: #edf9f8;
}
.a3dl.c2 {
	background-color: #f5f4ff;
}
.a3dl.c3 {
	background-color: #fff5f7;
}
.a3dl.c1 dt {
	color: #00ac9d;
}
.a3dl.c2 dt {
	color: #6f62c4;
}
.a3dl.c3 dt {
	color: #ff859e;
}
.a3h4 {
	color: #ff859e;
}
.jobWrap {
	border: 4px solid #ff859e;
	border-radius: 10px;
	padding-bottom: 4%;
}
.jobList {
	height: 40vw;
	overflow-y: scroll;
	padding: 0 4%;
	scrollbar-width: thin;
    scrollbar-color: #ccc #fff;
}
.jobList::-webkit-scrollbar {
  width: 6px;
}
.jobList::-webkit-scrollbar-track {
  background-color: #fff;
}
.jobList::-webkit-scrollbar-thumb {
  background-color: #ccc;
  border-radius: 3px;
}
@media screen and (min-width: 800px) {
    .mt2 {
        margin-top: 5px;
    }
    .a3Wrap {
        padding: 40px 0 60px;
    }
    .a3pointWrap.point2{
        padding-bottom: 35px;
    }
    .a3pointWrap {
        margin-top: 60px;
        padding-bottom: 50px;
    }
    .a32 img {
        margin-top: -45px;
    }
    .a3h3 {
        border-radius: 12.5px;
    }
    .a3dl {
        border-radius: 12.5px;
        padding: 15px 20px;
    }
    .jobList {
        height: 200px;;
    }
}
/*3つのおすすめコース
-------------------------------------------------------*/
.a4Wrap {
	background-color: #ffe7ec;
	padding: 0 0 15vw;
}
.a41 img {
	margin-top: -5vw;
}
.a4courseWrap {
	background-color: #fff;
	border-radius: 15px;
	box-shadow: 0 0 15px rgba(0,0,0,.15);
	margin-top: 10vw;
	padding-bottom: 5vw;
}
.courseHead {
	border-radius: 15px 15px 0 0;
	background-color: #ec547b;
	padding: 0.5rem;
}
.imgOsusume {
	margin-top: -6vw;
}
.a4h3 {
	line-height: 1.4;
}
.a4w {
	padding: 0 6%;
}
.a4h4 {
	color: #ec547b;
}
.a4h4 small {
	font-size: 60%;
}
.a4txt1 {
	background-color: #ffe7ec;
}
.ulCourse span {
	color: #ec547b;
}
.priceDef {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	margin-right: 5vw;
}
.priceDef big {
	font-size: 150%;
	padding-bottom: 5px;
	padding-left: 0.5rem;
	padding-right: 0.15rem;
	text-decoration: line-through 1px;
	text-decoration-color: #ec547b;
}
.priceDef::after {
	content: '';
	display: inline-block;
	width: 3.5vw;
	height: 4vw;
	background: url("../img/a4arw.png") no-repeat;
	background-size: contain;
	margin-top: 3vw;
	margin-left: 2vw;
}
.cFfff00 {
	color: #ffff00;
}
.priceOffFlex {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.off {
	width: fit-content;
	background: url("../img/a4off.png") no-repeat;
	background-size: 100% 100%;
	line-height: 1.0;
	padding: 0.25rem 2.5vw 0.75rem 1.5vw;
}
.priceOff {
	color: #ec547b;
	line-height: 0.5;
}
.priceOff small {
	font-size: 60%;
}
.ctaCourse a {
	display: block;
}
.blnWrap {
	width: 19vw;
	height: 19vw;
	position: absolute;
	top: -11vw;
	left: 1.5vw;
}
.bln {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -60%);
	line-height: 1.2;
	white-space: nowrap;
}
@media screen and (min-width: 800px) {
    .a4Wrap {
        padding: 0 0 60px;
    }
    .a41 img {
        margin-top: -25px;
    }
    .a4courseWrap {
        margin-top: 40px;
        padding-bottom: 30px;
    }
    .imgOsusume {
        margin-top: -30px;
    }
    .priceDef {
        margin-right: 20px;
    }
    .priceDef big {
    }
    .priceDef::after {
        width: 15px;
        height: 20px;
        margin-top: 15px;
        margin-left: 7px;
    }
    .off {
        width: fit-content;
        background: url("../img/a4off.png") no-repeat;
        background-size: 100% 100%;
        line-height: 1.0;
        padding: 0.25rem 15px 0.75rem 10px;
    }
    .blnWrap {
        width: 90px;
        height: 90px;
        top: -45px;
        left: 10px;
    }
}
.online .a4h4 {
	line-height: 1.0;
	margin: 10px 0;
}
.priceDefNormal {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	line-height: 0;
	margin-top: 25px;
}
.priceDefNormal big {
	font-size: 200%;
	padding-bottom: 15px;
	padding-left: 0.5rem;
	padding-right: 0.15rem;
}
.online .blnWrap {
	top: -15vw;
}
@media screen and (min-width: 800px) {
    .online .a4h4 {
        line-height: 1.2
    }
    .priceDefNormal {
        line-height: 0.25;
        margin-top: 30px;
    }
    .online .blnWrap {
        top: -70px;
    }
}
/*コース一覧
-------------------------------------------------------*/
.a5Wrap {
	padding: 10vw 0 0;
}
.a51 {
	line-height: 1.4;
}
.a51 big {
	display: block;
}
.a5h2 {
    position: relative;
    padding: 0.5rem 0;
    cursor: pointer;
	padding-left: 4vw;
}
.a5h2 span::before, .a5h2 span::after {
    content: '';
    display: inline-block;
    width: 16px;
    height: 1.5px;
    background-color: #fff;
    position: absolute;
    right: 4vw;
    top: 50%;
    transform: translateY(-50%);
    transition: opacity .4s;
}
.a5h2 span::after {
    transform: translateY(-50%) rotate(90deg);
    transition: transform .4s;
}
.a5h2.on span::before {
    opacity: 0;
}
.a5h2.on span::after {
    transform: translateY(-50%) rotate(180deg);
}
.courseList {
	display: none;
}
.a5h3 {
	padding: 0.5rem 4vw;
}
.courseWrap {
	padding: 3vw 4vw;
}
.border {
	padding-top: 1rem;
	margin-top: 1rem;
}
.a5h4 span {
	border-radius: 5px;
	padding: 0 0.75rem;
	margin-left: 1rem;
}
.strike {
	text-decoration: line-through 1px;
	text-decoration-color: #ec547b;
}
.offList span {
	border-radius: 5px;
	padding: 0 0.5rem;
}
.offList {
	line-height: 1.2;
}
.offList big {
	padding-left: 1rem;
}
.school .a5h2 {
    background-color: #ff859e;
}
.school .courseList {
	border: 1px solid #ff859e;
}
.school .a5h3 {
	background-color: #ffe7ec;
    color: #ec547b;
	border-top: 1px solid #ec547b;
}
.school .a5h4 {
    color: #ec547b;
}
.school .a5h4 span {
	background-color: #ffe7ec;
}
.school .a5ul span {
    color: #ec547b;
}
.school .border {
	border-top: 1px dashed #ec547b;
}
.school .offList span {
	background-color: #ec547b;
}
.school .offList {
	color: #ec547b;
}
.online .a5h2 {
    background-color: #66cdc4;
}
.online .courseList {
	border: 1px solid #66cdc4;
}
.online .a5h3 {
	background-color: #e0f5f3;
    color: #00ac9d;
	border-top: 1px solid #00ac9d;
}
.online .a5h4 {
    color: #00ac9d;
}
.online .a5h4 span {
	background-color: #e0f5f3;
}
.online .a5ul span {
    color: #00ac9d;
}
.online .border {
	border-top: 1px dashed #66cdc4;
}
.online .offList span {
	background-color: #00ac9d;
}
.online .offList {
	color: #00ac9d;
}
@media screen and (min-width: 800px) {
    .a5Wrap {
        padding: 50px 0 0;
    }
    .a5h2 {
        padding: 0.5rem 0;
        padding-left: 25px;
    }
    .a5h2 span::before, .a5h2 span::after {
        right: 25px;
    }
    .a5h3 {
        padding: 0.5rem 25px;
    }
    .courseWrap {
        padding: 15px 25px;
    }
}
/*お支払い方法について
-------------------------------------------------------*/
.a6Wrap {
	padding: 7.5vw 0;
}
.paymentWrap {
	background-color: #d4eef9;
	border-radius: 15px;
	padding: 6vw 0;
}
.a6catch {
	color: #1a467a;
    line-height: 1.5;
    display: flex;
    justify-content: center;
    align-items: center;
}
.a6catch::before, .a6catch::after {
    width: 1px;
    height: 11vw;
    content: "";
    background-color: #1a467a;
}
.a6catch::before {
    transform: rotate(-25deg);
	margin-right: 2rem;
}
.a6catch::after {
    transform: rotate(25deg);
	margin-left: 1rem;
}
.a61 {
	color: #1a467a;
}
.payCont {
	margin: 0 4vw;
}
.a6h3 {
	padding: 0.25rem 0;
	border-radius: 10px 10px 0 0;
	background-color: #29abe2;
}
.payDtl {
	padding: 6vw 4vw 4vw;
	border-radius: 0 0 10px 10px ;
	border: 1px solid #29abe2;
	background-color: #fff;
}
.payDtl img {
	margin-top: -7vw;
}
.payDtl.payDtl2 {
	padding: 3vw;
}
@media screen and (min-width: 800px) {
    .a6Wrap {
        padding: 50px 0;
    }
    .paymentWrap {
        padding: 30px 0;
    }
    .a6catch::before, .a6catch::after {
        height: 50px;
    }
    .payCont {
        margin: 0 25px;
    }
    .payDtl {
        padding: 25px 20px 20px;
    }
    .payDtl img {
        margin-top: -32px;
    }
    .payDtl.payDtl2 {
        padding: 15px;
    }
}
/*開講校舎一覧
-------------------------------------------------------*/
.a7Wrap {
	padding: 7.5vw 0 15vw;
	background-color: #ffe7ec;
}
.schoolList {
	display: flex;
	flex-flow: wrap;
	gap: 4rem 4%;
}
.schoolListWrap {
	width: 48%;
}
.a7h3 {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.a7h3 span {
	background-color: #ec547b;
	border-radius: 5px;
	line-height: 1;
	padding: 0.25rem 0.5rem;
}
.schoolListWrap .border {
	border-top: 1px solid #ffc2c2;
	margin-top: 0.4rem;
	padding-top: 0.4rem;
}
@media screen and (min-width: 800px) {
    .a7Wrap {
        padding: 50px 0 80px;
    }
}
.ttlCtaCam {
	margin-top: -5vw;
}
@media screen and (min-width: 800px) {
    .ttlCtaCam {
        margin-top: -33px;
    }
}
/*電話でのお問い合わせ
-------------------------------------------------------*/
.telWrap {
	background-color: #f2ede5;
	padding: 5vw;
}
.telCont {
	background-color: #fff;
	border-radius: 15px;
	padding: 5vw 5vw;
}
.telScholl {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.second {
	border-top: 1px solid #e6e6e6;
	border-bottom: 1px solid #e6e6e6;
	padding: 0.5rem 0;
	margin: 0.5rem 0;
}
.h3tel {
	background-color: #ff859e;
	border-radius: 5px;
	width: 40%;
}
@media screen and (min-width: 800px) {
    .telWrap {
        padding: 30px;
    }
    .telCont {
        padding: 25px 30px;
    }
}
@media(min-width: 800px){
    a[href*="tel:"] {
        pointer-events: none;
        cursor: default;
    }
}
/*フッターロゴ
-------------------------------------------------------*/
.fLogoWrap{
	padding: 2vw 0 1vw;
}
.mgAuto {
	margin: auto;
}
@media screen and (min-width: 800px) {
    .fLogoWrap{
        padding: 20px 0 10px;
    }
}
/*フッター
-------------------------------------------------------*/
.ctaBtnFot {
    width: 100%;
}
.ctaBtnFot a {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0 0 3vw;
	background-color: #ED862F;
}
.ctaArw {
    display: inline-block;
    width: 2.5vw;
    height: 2.5vw;
	border-radius: 2px;
	margin-top: 0.5rem;
    transform: rotate(135deg);
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
}
@media screen and (min-width: 800px) {
    .ctaBtnFot a {
        padding: 0 0 15px;
		gap: 1.5rem;
    }
    .ctaArw {
        width: 10px;
        height: 10px;
    }
}
footer {
    position: sticky;
    bottom: -100px;
    left: 0;
    width: 100%;
    z-index: 2;
	transition: all 0.6s;
}
footer.active {
    bottom: 0;
}
footer a:hover {
    filter: alpha(opacity=100);
    -moz-opacity:1;
    opacity:1;
}
/*フォーム
-------------------------------------------------------*/
.formWrap {
	padding: 10vw 0;
}
.ttlForm {
	width: 41vw;
}
.formCatch {
    line-height: 1.5;
    display: flex;
    justify-content: center;
    align-items: center;
}
.formCatch::before, .formCatch::after {
    width: 1px;
    height: 4.5vw;
    content: "";
    background-color: #000;
}
.formCatch::before {
    transform: rotate(-25deg);
	margin-right: 1.5rem;
}
.formCatch::after {
    transform: rotate(25deg);
	margin-left: 0.5rem;
}
@media screen and (min-width: 800px) {
    .formWrap {
        padding: 50px 0;
    }
    .ttlForm {
        width: 170px;
    }
    .formCatch::before, .formCatch::after {
        height: 22px;
    }
}
.progress {
	position: relative;
	width: 100%;
	z-index: 2;
}
.progressWrap {
	padding: 2.5vw 0 6.5vw;
	position: absolute;
	width: 100%;
	transition: all 0.6s;
}
.progressWrap.fix {
	background-color: rgba(0,0,0,.65);
	position: fixed;
	top: 50px;
	z-index: 1;
}
@media screen and (min-width: 800px) {
    .progress {
        width: 500px;
    }
    .progressWrap {
		padding: 1.5rem 0 3rem;
        width: 500px;
    }
}
.progressFlex {
	display: flex;
	justify-content: center;
	gap: 17vw;
	position: relative;
}
.progressFlex::before {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 50%;
	height: 3px;
	background-color: #ffe7ec;
}
.circle {
	width: 7.5vw;
	height: 7.5vw;
	border-radius: 50%;
	background-color: #ffe7ec;
	color: #ff859e;
    text-align: center;
	z-index: 0;
	position: relative;
	transition: all 0.6s;
}
.circle span {
    line-height: 7.5vw;
}
.circle.active {
	background-color: #ff859e;
	color: #fff;
}
.circle::before {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -5vw;
	color: #333;
	font-size: 12px;
	white-space: nowrap;
}
.progressWrap.fix .circle::before {
	color: #fff;
}
.circle.step1::before {
	content: '入力';
}
.circle.step2::before {
	content: '確認';
}
.circle.step3::before {
	content: '完了';
}
@media screen and (min-width: 800px) {
    .progressFlex {
        gap: 70px;
    }
    .circle {
        width: 40px;
        height: 40px;
    }
    .circle span {
        line-height: 40px;
    }
    .circle::before {
        bottom: -23px;
    }
}
.divForm {
	padding-top: 10vw;
}
@media screen and (min-width: 800px) {
    .divForm {
        padding-top: 60px;
    }
}
.formTable {
	width: 100%;
}
.formTable tr {
	display: flex;
	flex-flow: wrap;
	border-bottom: 1px solid #ccc;
}
.borderNone {
	border-bottom: none !important;
}
.formTable th,.formTable td {
	width: 100%;
}
.formTable th {
	padding-top: 15px;
}
.formTable td {
	padding: 15px 0;
}
.formTable th .required , .formTable th .any  {
	line-height: 1.0;
	padding: 0 0.5rem;
	border-radius: 50px;
	margin-left: 1rem;
}
.formTable th .required {
	background-color: #ec547b;
}
.formTable th .any {
	background-color: #b3b3b3;
}
a.privacy {
	text-decoration: underline;
}
input::placeholder,textarea::placeholder {
	color: #b3b3b3;
}
.formTable input[type=text],
.formTable input[type=email],
.formTable input[type=tel],
.formTable textarea,
.formTable select {
    width: 100%;
	border: none;
	border-radius: 0;
	box-shadow: none;
	background-color: #f2f2f2;
	padding: 15px;
	margin: 0;
	vertical-align: auto;
    appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
    -o-appearance: none;
    -ms-appearance: none;
	-moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
	font-size: 16px;
}
.formTable label {
    padding: 5px 10px 5px 0;
	white-space: nowrap;
	display: inline-block;
}
.submitBtn {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.submitBtn button {
    /* background: linear-gradient(to top, #07b429, #0c912d, #0cae2d, #d2f6d7);
	border: 1px solid #0c912d; */
    border: 1px solid #fff;
    background: linear-gradient(to top, #b85300,   /* 深いオレンジ */
    #d96a00,   /* メインオレンジ */
    #f5841f,   /* 明るめオレンジ */
    #ffb066);
    border-radius: 10vw;
    padding: 25px 0;
    color: #FFF;
    width: 100%;
    margin: 0 auto;
    display: block;
	box-shadow: 1px 1px 3px rgba(0,0,0,.35);
	position: relative;
    cursor: pointer;
}
.submitBtn button::after {
	content: '';
	position: absolute;
	top: 50%;
	transform: translateY(-90%) rotate(135deg);
	right: 25px;
    display: inline-block;
    width: 12px;
    height: 12px;
	border-radius: 2px;
	margin-top: 0.5rem;
    border-top: 2px solid #fff;
    border-left: 2px solid #fff;
}
.submitBtn .backBtn {
	background: #fff;
	border: 1px solid #ff859e;
	color: #ff859e;
	padding: 14px 0;
	box-shadow: none;
	font-size: 20px;
}
.submitBtn .backBtn::after {
	display: none;
}
form[data-form-step="input"] .submitBtn .backBtn,
form[data-form-step="complete"] .submitBtn .backBtn {
	display: none;
}
.dateWrap {
	display: flex;
	justify-content: space-between;
}
.selectWrap {
	position: relative;
	width: 30%;
}
.selectWrap::after {
    content: "";
    position: absolute;
    right: 10px;
    top: 50%;
    width: 4px;
    height: 4px;
    border-top: 2px solid #ccc;
    border-left: 2px solid #ccc;
    transform: translateY(-50%) rotate(-135deg);
    font-size: 12px;
    pointer-events: none;
}
.formTable input[type=text].date {
	width: 65%;
}
.formTable select.time {
}
/*datepicker
-------------------------------------------------------*/
@media screen and (min-width: 800px) {
    .ui-widget {
        font-size: 15px;
    }
}
.ui-widget-header {
    border: 1px solid #ff859e;
    background: #ff859e;
    color: #fff;
    font-weight: bold;
}
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active {
    border: 1px solid #ff859e;
    background: #fff;
    font-weight: normal;
    color: #ff859e;
	text-align: center;
}
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {
    border: 1px solid #ff859e;
    background: #ff859e;
    color: #fff;
    font-weight: bold;
}
.ui-widget-header .ui-icon {
    background: url("../img/ui-icons.png") no-repeat;
	background-size: contain;
}
.ui-widget-header .ui-icon.ui-icon-circle-triangle-w {
	transform: rotate(180deg);
}
/*キラキラ
-------------------------------------------------------*/
/*.kiraBtn {
	overflow: hidden;
	border-radius: 100px;
}
.kiraBtn a,
.submitBtn button {
    position: relative;
    display: block;
}
.kiraBtn a::before,
.submitBtn button::before {
    position: absolute;
    content: '';
    top: 50%;
	transform: translateY(-50%) skewX(-45deg);
    left: -100%;
    width: 100%;
    height: 100%;
    transform: skewX(-45deg);
    animation: nyainy-btn 2.5s cubic-bezier(0.55, 0.085, 0.68, 0.53) infinite;
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.85) 45%, rgba(255, 255, 255, 0) 100%);
}
.kiraBtn.w90 a::before {
    width: 70%;
	height: 84%;
	margin: auto;
}
@keyframes nyainy-btn {
    0% {
        left: -100%;
    }
    25% {
        left: 100%;
    }
    100% {
        left: 100%;
    }
}*/
.kiraBtn {
    /* display: block;
    animation: heartBeat 2s linear .5s infinite forwards;
    transform-origin: 50% 50%; */
/* @keyframes heartBeat {
  0% {
    transform: scale(1);
  }

  30% {
    transform: scale(1);
  }

  40% {
    transform: scale(1.1);
  }

  50% {
    transform: scale(1);
  }

  60% {
    transform: scale(1.1);
  }

  70% {
    transform: scale(1);
  }

  100% {
    transform: scale(1);
  }
} */
 }

/* CTAボタン縦並びラッパー */
.cta-flex {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 93%;
  margin: 14px auto;
}
.cta-flex .ctaMain {
  width: 100%;
  margin: 0;
}

/* CTAボタン本体 */
.cta-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
  min-height: 0px;
  height: 80px;
  padding: 12px 40px 12px 16px;
  border-radius: 50px;
  background: linear-gradient(to top, #07a828, #0cb92d, #2dd44e, #a8f0b8);
  border: 3px solid #fff;
  box-shadow: 0 4px 15px rgba(7, 180, 41, 0.4), 0 0 8px rgba(7, 180, 41, 0.2);
  text-decoration: none;
  overflow: hidden;
  transition: box-shadow 0.3s, transform 0.3s;
}
.cta-btn:hover {
  filter: none;
  opacity: 1;
  box-shadow: 0 6px 25px rgba(7, 180, 41, 0.6), 0 0 15px rgba(241, 196, 15, 0.4);
  transform: translateY(-2px);
}

/* テキスト中央配置 */
.cta-text {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.3;
}
.cta-title {
  font-size: calc(100vw * 17 / 400);
  font-weight: 900;
  color: #fff;
  text-shadow: 1px 1px 2px rgba(0,0,0,0.3);
}
.cta-sub {
  font-size: calc(100vw * 13 / 400);
  font-weight: 700;
  color: #fff;
  margin-top: 2px;
}
@media screen and (min-width: 600px) {
  .cta-title {
    font-size: calc(100vw * 17 / 600);
  }
  .cta-sub {
    font-size: calc(100vw * 13 / 600);
  }
}
@media screen and (min-width: 800px) {
  .cta-title {
    font-size: calc(500px * 16 / 450);
  }
  .cta-sub {
    font-size: calc(500px * 13 / 450);
  }
}

/* 矢印（右端固定） */
.cta-arrow {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 10px;
  height: 10px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  flex-shrink: 0;
}

/* キラッと流れる光アニメーション */
.cta-btn::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0.1) 20%,
    rgba(255,255,200,0.5) 40%,
    rgba(255,255,255,0.8) 50%,
    rgba(255,255,200,0.5) 60%,
    rgba(255,255,255,0.1) 80%,
    rgba(255,255,255,0) 100%
  );
  transform: skewX(-25deg);
  animation: shineFlow 3s ease-in-out infinite;
}
@keyframes shineFlow {
  0% {
    left: -100%;
  }
  30% {
    left: 150%;
  }
  100% {
    left: 150%;
  }
}

/* ボタン全体のグロウアニメーション（緑） */
.kiraBtn .cta-btn {
  animation: glowPulseGreen 2.5s ease-in-out infinite;
}
@keyframes glowPulseGreen {
  0%, 100% {
    box-shadow: 0 4px 15px rgba(7, 180, 41, 0.4), 0 0 8px rgba(7, 180, 41, 0.2);
  }
  50% {
    box-shadow: 0 4px 20px rgba(7, 180, 41, 0.6), 0 0 25px rgba(241, 196, 15, 0.35), 0 0 40px rgba(7, 180, 41, 0.15);
  }
}

/* オレンジボタン */
.cta-btn.cta-btn--orange {
  background: linear-gradient(to top, #b85300,   /* 深いオレンジ */
    #d96a00,   /* メインオレンジ */
    #f5841f,   /* 明るめオレンジ */
    #ffb066 );
  box-shadow:
    0 4px 15px rgba(217, 106, 0, 0.45),
    0 0 10px rgba(217, 106, 0, 0.25);
  animation: glowPulseOrange 2.5s ease-in-out infinite;
}
.cta-btn.cta-btn--orange:hover {
  box-shadow:
    0 6px 25px rgba(217, 106, 0, 0.65),
    0 0 20px rgba(255, 140, 40, 0.45);
}
.cta-btn--orange .cta-title {
  color: #fff;
}
@keyframes glowPulseOrange {
  0%, 100% {
    box-shadow:
      0 4px 15px rgba(217, 106, 0, 0.45),
      0 0 10px rgba(217, 106, 0, 0.25);
  }
  50% {
   box-shadow:
      0 4px 22px rgba(217, 106, 0, 0.65),
      0 0 28px rgba(255, 140, 40, 0.4),
      0 0 45px rgba(217, 106, 0, 0.2);
  }
}

















