html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
}
body {
	font: inherit;
	vertical-align: baseline;
	line-height: 1;
	margin-block-start: 0;
	margin-block-end: 0;
	margin-inline-start: 0;
	margin-inline-end: 0;
	padding-inline-start: 0;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

ol, ul {
	list-style: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

html {
	font-size: 10px;
}

body {
	font-family: 'Noto Sans JP', serif;
	font-size: 17px;
	color: #313131;
	font-weight: 500;
}

input, textarea, select, button {
	font-family: 'Noto Sans JP', serif;
}

a {
	text-decoration: none;
}

.showSp {
	display: none !important;
}

.wrapper {
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	padding-top: 101px;
}

.wrapperContent {
	width: 100%;
	max-width: 750px;
}

@media screen and (max-device-width: 480px){
  body{
    -webkit-text-size-adjust: none;
  }
}

/*header block*/
.headerInner {
	display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 7px 18px 14px 14px;
    box-sizing: border-box;
    position: fixed;
    left: 50%;
    top: 0;
    z-index: 9999;
    background-color: rgba(255,255,255,.8);
    width: 100%;
    max-width: 750px;
    transform: translate(-50%, 0);
}

.headerInner .headerLogo img {
	height: 80px;
}

.headerInner .headerContact img {
	height: 68px;
}
/*end header block*/

/*banner block*/
.banner {
	position: relative;
}

.banner .fvRainbow {
	position: absolute;
	width: 70.26%;
	left: 50%;
	bottom: 57px;
	transform: translate(-50%, 0);
}

.banner .fvText {
	position: absolute;
	width: 470px;
	right: 28px;
	top: 34px;
}
/*end banner block*/

/*group btn*/
.groupBtn {
	margin-top: -1px;
	background-color: #ED7D31;
	padding: 12px 0 0 0;
	box-sizing: border-box;
	text-align: center;
}

.groupBtn .groupBtnTitle {
	display: inline-block;
}

.groupBtn a {
	text-align: center;
	display: block;
}

.groupBtn p {
	font-size: 35px;
	color: #FFFFFF;
	font-weight: 700;
	position: relative;
	display: inline-block;
	margin-bottom: 10px;
}

.groupBtn p img {
	position: absolute;
	bottom: -10px;
}

.groupBtn p img.leftW {
	left: -20px;
}

.groupBtn p img.righttW {
	right: -20px;
}

.groupBtn p span {
	font-size: 65px;
	font-family: "Oswald";
}

.groupBtn a img {
	display: inline-block;
}
/*end group btn*/

/*infection*/
.infectionCrn {
	text-align: center;
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/infecBg.png");
	background-repeat: no-repeat;
	background-size: 100% 100%;
	color: #030303;
	padding: 42px 0;
	box-sizing: border-box;
}

.infectionCrn .infecTitle {
	font-size: 34px;
	line-height: 1.29;
	margin-bottom: 15px;
	font-weight: bold;
}

.infectionCrn .infecDes {
	width: 685px;
	background-color: rgba(255, 255, 255, 0.69);
	font-size: 24px;
	line-height: 1.4;
	padding: 20px 0;
	margin: 0 auto;
}
/*end infection*/

/*learning*/
.blockLearning {
	position: relative;
}

.studentGirl {
	height: 456px;
	left: 35px;
	bottom: 41px;
	position: absolute;
}
/*end learning*/

/*school info*/
.schoolInfo {
	border: 7px solid #ED7D31;
	box-sizing: border-box;
	padding: 35px 0 56px 0;
}

.sInfoTitle {
	margin-bottom: 41px;
	text-align: center;
}

.sInfoTitle img {
	display: inline-block;
}

.schoolInfoVideo {
	padding: 14px;
	background-color: #F1F1F1;
	width: 672px;
	margin: 0 auto;
	box-sizing: border-box;
}
/*end school info*/

/*concept*/
.concept {
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/conceptBg.png");
	background-repeat: no-repeat;
	background-size: 100%;
	background-position: top;
	padding: 185px 0 132px 0;
	box-sizing: border-box;
	position: relative;
}

.conceptTitle {
	text-align: center;
	margin-bottom: 75px;
}

.conceptTitle p {
	font-family: "Oswald";
	font-size: 63px;
	line-height: 93px;
	font-weight: 700;
	color: #FFF;
	text-align: center;
}

/*.conceptTitle img {
	display: inline-block;
}*/

.conceptDes {
	text-align: center;
	letter-spacing: -0.25rem;
	padding-top: 25px;
	position: relative;
}

.conceptDes:after {
	position: absolute;
	content: '';
	width: 399px;
	height: 1px;
	background-color: #FFF;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0);
}

.conceptDes p {
	font-size: 25px;
	color: #FFF;
	line-height: 1.56;
	margin-bottom: 45px;
	font-weight: 500;
}

.conceptDes p:last-child {
	margin-bottom: 0;
}

.conceptDes p.conceptDesTitle {
	font-size: 48px;
	line-height: 1.166667;
	margin-bottom: 38px;
	font-weight: bold;
	font-family: "Oswald";
}
/*end concept*/

/*music school*/
.musicSchool {
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/musicBg.png");
	background-repeat: no-repeat;
	background-size: 100% 100%;
	padding: 120px 0 60px 0;
	box-sizing: border-box;
    margin-top: -85px;
}

.musicSchoolTitle {
	margin-bottom: 48px;
	text-align: center;
}

.musicSchoolTitle img {
	display: inline-block;
}

.listLogo {
	margin-bottom: 37px;
}

.listLogo ul {
	width: 576px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.listLogo ul::after {
  height: 0;
  width: 31.9%;
  content: "";
}

.listLogo ul li {
	width: 31.9%;
	margin-bottom: 10px;
}

.listLogo ul li img {
	width: 100%;
}

.musicSchoolDes {
	text-align: center;
}

.musicSchoolDes p {
	color: #FFF;
	font-size: 24px;
	line-height: 1.291;
	display: inline-block;
	text-align: left;
}
/*end music school*/

/*list mv*/
.mvItem {
	padding: 60px 0 35px 0;
	box-sizing: border-box;
}

.mvItem .mvTitle {
	position: relative;
	margin-bottom: 40px;
}

.mvTitleHeight {
	height: 76px;
	display: flex;
	align-items: center;
	z-index: 1;
	position: relative;
	padding-left: 250px;
	box-sizing: border-box;
}

.mvItem .mvTitle:before {
	content: '';
	width: 677px;
	height: 76px;
	position: absolute;
	background-color: #FFFE00;
	left: 0;
	bottom: 0;
	z-index: 0;
}

.mvItem .mvTitle .mvAvatar {
	position: absolute;
	width: 170px;
	height: 170px;
	border-radius: 50%;
	left: 65px;
	bottom: -35px;
}

.mvItem .mvTitle p {
	font-size: 23px;
	line-height: 1.7;
	margin-left: 236px;
	display: inline-block;
	letter-spacing: -0.1rem;
}

.mvItem .mvVideo {
	text-align: center;
}

.mvBlackBg {
	background-color: rgba(3, 3, 3, 0.74);
}

.mvBlackBg .mvTitle p {
	color: #FFF;
}
/*end list mv*/

/*purpose*/
.purpose {
	margin-top: -33px;
}

.purposeTitle {
	overflow: hidden;
}

.purposeTitle img {
	margin-left: -55px;
	margin-top: -37px;
}

.listPurpose {
	margin-top: -25px;
}

.listPurpose .ppItem {
	background-color: #ED7D31;
	padding: 22px 0 36px 25px;
	box-sizing: border-box;
}

.ppItem .ppTitle {
	display: flex;
	align-items: center;
}

.ppItem .ppTitle p {
	font-size: 50px;
	color: #FFF;
	font-weight: bold;
	padding-left: 28px;
	box-sizing: border-box;
	position: relative;
}

.ppItem .ppTitle p span {
	font-size: 40px;
}

.ppItem .ppTitle img {
	position: relative;
}

.ppItem .ppImg {
	width: 665px;
	margin-left: auto;
	margin-right: 0;
	margin-top: -35px;
}

.ppItem .ppDes {
	width: 540px;
	margin-left: auto;
	margin-right: 0;
	margin-top: -15px;
}

.ppItem .ppDes p {
	font-size: 24px;
	color: #FFF;
	line-height: 1.458;
	border-bottom: 1px solid #FFFFFF;
	padding-bottom: 15px;
	padding-right: 17px;
}

.ppItem.ppItemWhite {
	background-color: #FFF;
}

.ppItem.ppItemWhite .ppTitle p {
	color: #030303;
	margin-top: -35px;
}

.ppItem .ppTitle p span.noteSmall {
	position: absolute;
	font-size: 12px;
	right: 0;
	bottom: -30px;
	font-weight: 300;
}

.ppItem.ppItemWhite .ppTitle.exTop p {
	margin-top: -90px;
}

.ppItem.ppItemWhite .ppTitle p strong{
	font-size: 27px;
	line-height: 1.5;
}

.ppItem.ppItemWhite .ppDes p {
	color: #030303;
	border-color: #030303;
}

.ppOvList {
	width: 720px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: -70px;
}

.ppOvList .ovItem {
	width: 47.22%;
	margin-left: auto;
    margin-right: auto;
}

.ppOvList .ovItem:first-child {
	margin-bottom: 50px;
}

.ppOvList .ovItem .ovImg {
	text-align: center;
	margin-bottom: -82px;
}

.ppOvList .ovItem .ovImg img {
	width: 297px;
	height: 297px;
	border-radius: 50%;
	display: inline-block;
}

.ppOvList .ovItem .ovDes {
	padding-left: 40px;
	box-sizing: border-box;
}

.ppOvList .ovItem .ovDes p {
	font-size: 18px;
	line-height: 1.6;
	color: #030303;
}

.ppOvList .ovItem .ovTitle {
	width: 340px;
	height: 115px;
	margin: 0 auto;
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/ovTT.svg");
	background-repeat: no-repeat;
	background-size: 100% 100%;
	position: relative;
}

.ppOvList .ovItem .ovTitle p {
	font-size: 24px;
	color: #FFF;
	font-weight: bold;
	text-align: center;
	position: absolute;
	display: inline-block;
	white-space: nowrap;
	left: 52%;
	transform: rotate(-3deg) translate(-50%, 0);
	bottom: 27px;
}

.ppOvList .ovItem:first-child .ovTitle p {
    left: 57%;
}

.ppOvList .ovItem .ovTitle span {
	position: absolute;
	font-size: 36px;
	font-weight: 700;
	font-family: "Oswald";
	color: #FD8D02;
	left: 44px;
	top: 32px;
}
/*end purpose*/

/*footer*/
footer {
	background-color: #000000;
	border: 1px solid #707070;
	padding: 40px 0 35px 0;
	box-sizing: border-box;
	margin-bottom: 195px;
}

.footerLink {
	display: flex;
	justify-content: center;
	margin-bottom: 8px;
}

.footerLink a {
	font-size: 28px;
	color: #FFF;
	line-height: 1.464;
}

/*
.footerLink a:first-child {
	margin-right: 56px;
}
*/

.copyRight {
	font-size: 18px;
	color: #FFF;
	text-align: center;
	line-height: 1.5;
	font-weight: 500;
}
/*end footer*/

/*qa block*/
.collapsibleContent {
	display: none;
}

.qa {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.qaList {
	width: 711px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.qaItem {
	margin-bottom: 3px;
	width: 100%;
}

.qa .collapsible {
    display: block;
    margin: 0 auto;
    position: relative;
    font-size: 29px;
    line-height: 1.48;
    width: 100%;
    font-weight: bold;
    text-align: left;
    padding: 15px 17px;
    color: #FFF;
    box-sizing: border-box;
    cursor: pointer;
    outline: none;
    border: none;
    background: #030303;
}

.qa .collapsible.noWrapLine {
	letter-spacing: -0.2rem;
}

.qa .collapsible:after {
    content: '';
    position: absolute;
    width: 23px;
	height: 12px;
	background: url("https://zest-music.jp/ac/lp/music/counseling02/images/qaIcon.svg");
	background-repeat: no-repeat;
	background-size: 100% 100%;
    right: 18px;
    top: 50%;
    transform: translate(0, -50%);
}

.qa .collapsibleContent {
	font-size: 25px;
	font-weight: 500;
	line-height: 1.48;
	padding: 23px 6px 100px 6px;
	box-sizing: border-box;
	color: #030303;
	/*white-space: nowrap;*/
}

.qaTitle {
	text-align: center;
	margin-bottom: 45px;
}

.qaTitle img {
	display: inline-block;
}
/*end qa block*/

/*rainbow*/
.titleRainBow {
	display: flex;
	height: 151px;
	justify-content: center;
	align-items: center;
	background: url("https://zest-music.jp/ac/lp/music/counseling02/images/rainBowTitle.png");
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.titleRainBow p {
	text-align: center;
	font-size: 54px;
	color: #FFF;
	font-weight: 700;
	text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
/*end rainbow*/

/*list shop*/
.listShop {
	margin-bottom: 42px;
}

.listShopImg {
	width: 688px;
	margin-left: 39px;
}

.listShopImg ul {
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.listShopImg ul {
	padding-top: 72px;
	padding-bottom: 6px;
}

.listShopImg ul li {
	width: 46.95%;
	margin-bottom: 65px;
}

.listShopImg ul li .itemImgShop {
	margin-bottom: 12px;
	position: relative;
}

.listShopImg ul li .itemImgShop:after {
	content: '';
	position: absolute;
	width: 94.11%;
	height: 96.7%;
	background-color: rgba(240, 193, 88, 0.3);
	top: -10px;
	right: -7px;
}

.listShopImg ul li .itemImgShop:before {
	content: '';
	z-index: 2;
	left: -18px;
	top: -38px;
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 69px 69px 0 0;
	border-color: rgba(237, 125, 49, 0.87) transparent transparent transparent;
}

.listShopImg ul li img {
	max-width: 100%;
	position: relative;
	z-index: 1;
}

.listShopImg ul li .itemImgShopTitle p {
	font-size: 14px;
	color: #030303;
	font-weight: 400;
	padding-bottom: 12px;
	box-sizing: border-box;
	width: 218px;
	max-width: 100%;
	border-bottom: 1px solid #707070;
	margin: 0 auto;
	text-align: center;
}

.ls {
	width: 100%;
	margin: 0 auto;
	padding: 0;
}

.lsList {
	width: 711px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.lsItem {
	margin-bottom: 3px;
	width: 100%;
}

.ls .collapsible {
    display: block;
    margin: 0 auto;
    position: relative;
    font-size: 51px;
    line-height: 1.48;
    width: 673px;
    height: 129px;
    font-weight: bold;
    text-align: center;
    color: #FFF;
    box-sizing: border-box;
    cursor: pointer;
    outline: none;
    border: none;
    background: url("https://zest-music.jp/ac/lp/music/counseling02/images/bgShopTitle.png");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    border-radius: 6px;
}

.ls .collapsible.noWrapLine {
	letter-spacing: -0.2rem;
}

.ls .collapsible:after {
    content: '';
    position: absolute;
    width: 38px;
	height: 19px;
	background: url("https://zest-music.jp/ac/lp/music/counseling02/images/qaIcon.svg");
	background-repeat: no-repeat;
	background-size: 100% 100%;
    right: 18px;
    top: 50%;
    transform: translate(0, -50%);
}

.ls .collapsibleContent {
	background-color: transparent;
}

.ls .msContent {
	font-size: 35px;
	line-height: 1.272;
	padding: 15px 0 28px 0;
	box-sizing: border-box;
	color: #030303;
	width: 655px;
    margin: 0 auto;
    background-color: #FFFFE5;
    display: flex;
    justify-content: center;
    align-items: center;
}

.ls .collapsibleContent .colLeft {
	width: 41.52%;
	margin-right: 30px;
}

.ls .collapsibleContent .colRight {
	width: 100%;
	margin-left: 10px;
}

.ls .collapsibleContent .colRight p {
	margin-bottom: 20px;
	font-weight: 300;
}

.ls .collapsibleContent .colRight p span {
	display: block;
	margin-bottom: 5px;
}

.ls .collapsibleContent .colRight p:last-child {
	margin-bottom: 0;
}
/*end list shop*/

/*entertainment*/
.entertainment {
	position: relative;
}

.entertainment .enterTop {
	top: 190px;
	right: 150px;
	font-size: 25px;
	font-weight: bold;
	color: #FFF;
	font-weight: 700;
	line-height: 1.48;
	position: absolute;
	text-align: center;
	text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}

.entertainment .enterTop strong {
	font-size: 52px;
}

.entertainment .enterBot {
	left: 77px;
	bottom: 113px;
	position: absolute;
	font-size: 29px;
	color: #FFF;
	font-weight: 500;
	line-height: 1.482;
	text-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}
/*end entertainment*/

/*table price*/
.tablePrice {

}

.titleTable {
	position: relative;
}

.titleTable .logoAndText {
	position: absolute;
	text-align: center;
	top: 186px;
	left: 50%;
	transform: translate(-50%, 0);
}

.titleTable .logoAndText img  {
	display: inline-block;
	margin-bottom: 16.2px;
}

.titleTable .logoAndText p  {
	display: block;
	font-size: 32px;
	font-weight: bold;
	color: #FFF;
	line-height: 1.156;
}

.tableContent {
	padding: 60px 0 15px 0;
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/tbBg.png");
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.tableContent img {
	display: block;
	margin: 0 auto;
}

.tableContent .tableTitleImg {
	margin-bottom: 43px;
}

.tableContent p {
	width: 70%;
	margin-right: 0;
	margin-left: auto;
	font-size: 10px;
	line-height: 1.3;
	color: #FFF;
	padding: 15px 20px 0 20px;
	box-sizing: border-box;
}
/*end table price*/

/*step up*/
.stepUp {
	padding: 72px 0 73px 0;
}

.stepUpTitle {
	margin-bottom: 57px;
}

.stepUpTitle img {
	display: block;
	margin: 0 auto;
}

.stepUpSkil {
	margin-bottom: 90px;
}

.stepUpSkil ul {
	display: flex;
	width: 545px;
	margin: 0 auto;
	justify-content: space-between;
}

.stepUpSkil li {
	width: 27.34%;
	position: relative;
}

.stepUpSkil li:after {
	content: "";
	bottom: 35px;
	right: -42px;
	position: absolute;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14.5px 0 14.5px 26px;
	border-color: transparent transparent transparent #8e8e8e;
}

.stepUpSkil li:last-child:after {
	display: none;
}

.stepUpSkil li img {
	border-radius: 50%;
	-webkit-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
	-moz-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
	box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
}

.stepUpSkil li p {
	font-size: 38px;
	line-height: 1.4;
	font-weight: bold;
	text-align: center;
	margin-top: 7px;
}

.stepUpSkil li p span {
	font-size: 24px;
	display: block;
	line-height: 1.6;
}

.stepItem {
	margin-bottom: 105px;
	position: relative;
}

.stepItem:after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -70px;
	transform: translate(-50%, 0);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 17.5px 0 17.5px;
	border-color: #8e8e8e transparent transparent transparent;
}

.stepList .stepItem:last-child:after {
	display: none;
}

.stepList .stepItem:last-child {
	margin-bottom: 0;
}

.stepItemTitle {
	width: 52.4%;
	margin-left: 27.7%;
	position: relative;
	margin-bottom: 42px;
}

.stepItemTitle img {
	position: absolute;
	border-radius: 50%;
	-webkit-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
	-moz-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
	box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
	left: -90px;
	top: 50%;
	transform: translate(0,-50%);
}

.stepItemTitle p {
	height: 62px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 32px;
	text-align: center;
	color: #FFF;
	font-size: 43px;
	font-weight: bold;
}

.stepItemSubTitle {
	margin-bottom: 30px;
}

.stepItemSubTitle p {
	font-size: 29px;
	font-weight: bold;
	line-height: 1.14;
	text-align: center;
}

.stepItemDes p {
	text-align: center;
	font-size: 24px;
	line-height: 1.166667;
	color: #030303;
}

.color62 {
	color: #76C762;
}

.bgColor62 {
	background-color: #76C762;
}

.color5E {
	color: #EEE15E;
}

.bgColor5E {
	background-color: #EEE15E;
}

.color52 {
	color: #E9BE52;
}

.color31 {
	color: #ED7D31;
}

.bgColor31 {
	background-color: #ED7D31;
}
/*end step up*/

/*teacher*/
.listTeacher {
	padding: 33px 0 38px 0;
}

.teacherInfo {
	margin-bottom: 45px;
}

.listTeacher .teacherInfo:last-child {
	margin-bottom: 0;
}

.teacherInfo .tcName {
	font-weight: bold;
	font-size: 44px;
	line-height: 1.4;
	color: #3B3B3B;
	margin-left: 16px;
	margin-bottom: 4px;
}

.teacherInfo .tcOrange {
	font-size: 29px;
	line-height: 1.45;
	color: #ED7D31;
	margin-left: 16px;
	margin-bottom: 15px;
	font-weight: 500;
}

.teacherInfo .tcDes {
	display: flex;
	align-items: center;
	margin-left: 16px;
	margin-bottom: 22px;
}

.teacherInfo .tcDes img {
	width: 24.37%;
	margin-right: 11px;
}

.teacherInfo .tcDes p {
	width: 73.6%;
	font-size: 22px;
	line-height: 1.36;
	color: #030303;
}

.teacherInfo .yellowDes {
	background-color: #FDFDD5;
	font-size: 24px;
	line-height: 1.3;
	color: #030303;
	padding: 35px 30px;
	box-sizing: border-box;
}

.teacherInfo .tcOrange.smallOrange {
	font-size: 28px;
}
/*end teacher*/



/* start form */
.contactForm {
	width: 946px;
	max-width: 100%;
	margin: 70px auto 0 auto;
}


.formTitle {
	font-size: 6.4rem;
	font-weight: bold;
	padding: 40px 0;
	text-align: center;
	color: #FFFFFF;
	background: #59A327;
}

.formBlock {
	padding-bottom: 40px;
}

.formContent {
	width: calc(100% - 388px);
	margin: 0 auto;
	overflow: hidden;
}

.formRow {
	display: flex;
	align-items: center;
	font-size: 3.7rem;
	margin-top: 86px;
}

.formContent .formRow:first-child {
	margin-top: 70px;
}

.formLeft {
	width: 30%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #313131;
}

.formLeft span {
	background: #030303;
	color: #fff;
	border-radius: 9px;
	width: 78px;
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: bold;
	font-size: 2.4rem;
}

.formRight {
	width: 67%;
	padding-left: 20px;
}

.formSelect select {
	width: 56%;
	height: 57px;
	border: 1px solid #030303;
    border-radius: 0;
    font-size: 2.9rem;
}

input, textarea, select, button {
	outline: none;
	font-size: 4rem;
}

.formRight input, .formRight textarea {
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
	border-radius: 0;
	border: 1px solid #030303;
	box-sizing: border-box;
	font-size: 3.6rem;
	padding-left: 20px;
}

.formRight input {
	width: calc(100% - 26px);
	height: 57px;
}

.formDateContent {
	display: flex;
	justify-content: space-between;
	margin: 24px 0;
}

.formDate .formDateContent input {
	width: 56%;
}

.formDate select {
	width: 18%;
	height: 57px;
	border: 1px solid #030303;
	border-radius: 0;
	font-size: 2.9rem;
}

.formRight textarea {
	width: 100%;
	height: 594px;
	font-size: 2.9rem;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}
.custom-checkbox {
	text-align: center;
	margin-bottom: 32px;
	margin-top: 32px;
}

.custom-checkbox label{
	/*margin: 0 15px 0 0;*/
}
.custom-checkbox input[type="checkbox"]{
	display: none;
}
.custom-checkbox .vir-label{
	cursor: pointer;
    padding-bottom: 32px;
    display: inline-block;
}

.custom-checkbox:last-child .vir-label{
    padding-bottom: 0px;
}

.custom-checkbox .vir-content{
    vertical-align: middle;
    margin-left: 24px;
	color: #000;
    font-weight: 500;
    font-size: 4rem;
}
.custom-checkbox .vir-checkbox{
	width: 34px;
    height: 34px;
	border: 1px solid #030303;
	background: #ffffff;
	vertical-align: middle;
	position: relative;
	display: inline-block;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}

.custom-checkbox input[type="checkbox"]:checked + .vir-label .vir-checkbox:before{
    content: "";
    background: #a3a3a3;
    border-radius: 100px;
    height: 22px;
    width: 22px;
    position: absolute;
    display: inline-block;
    top: 6px;
    left: 6px;
}

.custom-checkbox .vir-checkbox.square-style,
.custom-checkbox input[type="checkbox"]:checked + .vir-label .vir-checkbox.square-style:before{
	border-radius: 0px;
}


.formDes {
	width: calc(100% - 40px);
	max-width: 100%;
	margin: 0 auto;
	border: 1px solid #030303;
	padding: 36px 23px;
	box-sizing: border-box;
	margin-bottom: 40px;
	background: #fff;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}

.formDes p {
	color: #313131;
	text-align: justify;
	font-size: 4rem;
	line-height: 1.35;
}


.btnFormContact button {
    width: 357px;
    height: 106px;
    background-color: #ED7D31;
    color: #FFF;
    font-weight: bold;
    font-size: 3.7rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    margin: 0 auto;
    outline: none;
    border: none;
    padding: 0;
    cursor: pointer;
    padding-right: 23px;
    position: relative;
    margin-bottom: 17px;
}

.btnFormContact button:after {
	content: '';
	position: absolute;
	top: 50%;
    transform: translateY(-50%);
    right: 28px;
    width: 34px;
    height: 28px;
    background-image: url(https://zest-music.jp/ac/lp/music/counseling02/images/white_arrow.svg);
    background-size: 100% 100%;
    background-repeat: no-repeat;
}

#errors {
    outline: none;
    margin: 0 auto 40px auto;
    text-align: center;
    position: relative;
    color: #ff0000;
    font-weight: 400;
    font-size: 2.4rem;
}

.formRowSpec {
	align-items: flex-start;
}

.formRowSpec .formLeft span{
	margin-top: 16px;
}

.formRowSpec .formLeft {
	margin-top: 20px;
}

.formRowSpec .formLeft span {
	display: none;
}

.formRight .formDate span {
	position: relative;
}

.formDate span:before {
	content: '任意';
	position: absolute;
	left: -140px;
	top: 5px;
	background: #030303;
    color: #fff;
    border-radius: 9px;
    width: 78px;
    height: 46px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    font-size: 2.4rem;
}

.formDate div:first-child > span:before {
	content: '必須';
	background: #030303;
}
/* end form */

/*sp form*/
.contactForm {
	width: 100%;
}

.formContent {
    width: calc(100% - 110px);
}

.formDate select {
	font-size: 3.2rem;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}


.formLeft {
	width: 100%;
	justify-content: initial;
}

.formRight {
	width: 100%;
	padding-left: 0;
	margin-top: 20px;
}

.formRight input {
	width: 100%;
	font-size: 2.9rem;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}

.formLeft span {
	margin-left: 16px;
}

.formContent .formRow {
	margin-top: 32px;
	flex-wrap: wrap;
}

.formContent .formTextarea {
	margin-top: 0;
}

.formContent .formRow:first-child {
	margin-top: 65px;
}

.formRowSpec {
	align-items: center;
}

.formRowSpec .formLeft span {
	margin-top: 0;
}

.formRowSpec .formRight {
	margin-top: 24px;
}

.formDateContent {
	margin-bottom: 30px;
}

.formDate .formDateContent input {
	width: 65%;
}

.formSelect select {
	width: 65%;
	background-color: #FFF;
	-webkit-box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16); 
	box-shadow: 1px 2px 3px 0px rgba(0, 0, 0, 0.16);
}

.formDate select {
	width: 16%;
	background-color: #FFF;
}

.formDate select option,
.formSelect select option {
	font-size: 1.6rem;
}

.formDes p {
	font-size: 2.4rem;
}

.formDate span:before {
    left: calc(100% + 12px);
}

.formDate > div {
    margin-top: 20px;
    margin-bottom: 28px;
}


.p-reservations__line {
    background-color: #00c300;
    padding: 10px 20px;
    width: 80%;
    margin: 30px auto 0;
}

.p-reservations__line img {
    vertical-align: middle;
    width: 100%;
}
/*end sp form*/


.datepicker {
	font-size: 28px;
	width: 500px;
}

.datepicker--cell {
	height: 64px;
}

.datepicker--day-name {
	font-size: 1em;
}

.datepicker--nav-title, .datepicker--nav-action {
	font-size: 1em;
}

.datepicker--nav {
	min-height: 64px;
}

.datepicker--time-icon {
	font-size: 32px;
	width: 2em;
	height: 2em;
}

.datepicker--nav-action {
	width: 64px;
}

.datepicker--nav-action svg {
    width: 64px;
    height: 64px;
}

/*voice*/
.voice {
	background: url("https://zest-music.jp/ac/lp/music/counseling02/images/tgt.png") top right no-repeat, 
                url("https://zest-music.jp/ac/lp/music/counseling02/images/tgb.png") bottom left no-repeat;
    background-size: 100% auto;
}

.listVoice {
	overflow: hidden;
	padding: 100px 0 40px 0;
	box-sizing: border-box;
}

.voiceItem:first-child {
	margin-bottom: 75px;
}

.voiceItem .voiceItemTitle {
	border-top: 5px solid #F1C459;
	border-bottom: 1px solid #F1C459;
	transform: rotate(-5deg);
	padding: 25px 0;
	box-sizing: border-box;
	width: 110%;
	margin-left: -5%;
	margin-bottom: 40px;
	position: relative;
}

.voiceItem .voiceItemTitle img {
	position: absolute;
	left: 80px;
	top: -50px;
	width: 92px;
	transform: rotate(4deg);
}

.voiceItem .voiceItemTitle p {
	font-size: 56px;
	color: #E89D0E;
	font-weight: bold;
	text-align: center;
}

.voiceItem .voiceItemImg {
	width: 467px;
	max-width: 100%;
	margin: 0 auto;
	margin-bottom: 45px;
}

.voiceItem .voiceItemDes p {
	color: #030303;
	font-size: 24px;
	line-height: 1.458;
	width: 692px;
	max-width: 100%;
	margin: 0 auto;
}
/*end voice*/

/*message*/
.messageContent {
	padding: 154px 0 31px 0;
	box-sizing: border-box;
	background-image: url("https://zest-music.jp/ac/lp/music/counseling02/images/messageBg.png");
	background-repeat: no-repeat;
	background-size: 100% 100%;
}

.messageContent .greenMessage {
	font-size: 34px;
	line-height: 1.5;
	text-align: center;
	color: #74CC6A;
	margin-bottom: 50px;
}

.ske48 {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	margin-bottom: -24px;
}

.ske48 .colLeft {
	width: 34.26%;
	margin-right: 40px;
}

.ske48 .colRight {
	width: 510px;
	padding: 14px 0;
	box-sizing: border-box;
	background-color: #FFF;
}

.ske48 .colRight p {
	font-size: 30px;
	line-height: 1.4;
	color: #030303;
	border-top: 3px solid #EFBD57;
	border-bottom: 3px solid #EFBD57;
	padding: 15px 0 12px 40px;
}

.ske48 .colRight p span {
	font-size: 29px;
	font-weight: bold;
}

.ske48 .colRight p strong {
	font-size: 40px;
	line-height: 1;
}

.messageTextImg {
	height: 155px;
	margin-left: 50px;
	display: block;
	margin-bottom: 20px;
}

.messageContent .messageText {
	width: 734px;
	max-width: 100%;
	margin: 0 auto;
	box-sizing: border-box;
	background-color: rgba(255, 255, 255, 0.67);
	padding: 73px 28px 28px 28px;
}

.messageContent .messageText p {
	font-size: 24px;
	line-height: 1.5;
	color: #000000;
	margin-bottom: 40px;
}

.messageContent .messageText p:last-child {
	margin-bottom: 0;
}

.messageContent .messageText p span {
	background: linear-gradient(to top, rgba(255, 255, 87, 0.63) 65%, transparent 0);
}
/*end block message*/
.btnContactForm.fixedBtn {
    width: 100%;
    margin-top: 24px;
    text-align: center;
    position: fixed;
    bottom: 5px;
    z-index: 999;
    left: 50%;
    transform: translate(-50%, 0);
}

@media only screen and (min-width: 760px) {
  .btnContactForm.fixedBtn {
  	display: none;
  }

  footer {
  	margin-bottom: 0;
  }
  
  .btnLineOnSp {
	display: none;
  }
}