@media only screen and (max-width: 800px) {

	.page .cta {
		position: absolute;
		left: 50vw;
		transform: translate(-50%,0px);
		width: 70vw;
		text-align: center;
	}

	.kala .page img.title {
		max-width: 90vw !important;
		width: 90vw;
	}

	#header .cta.signup {
	}

	#header .cta.secondary {
		border: none;
		font-weight: 400;
		text-align: right;
	}

	#header .login {
		border: none;
		font-weight: 400;
		padding: 6px;
	}

	#header .onboarding {
		display: none;
		font-weight: 400;
		padding: 0px;
	}

	.mobile {
		display: block;
	}

	.gift-footer p {
		gap: 10px;
		flex-direction: column;
	}

	.big-screen {
		display: none;
	}

	.kala .page.unlock-your-kala.mobile {
		background: white;
		background-size: stretch;
		background-position: 70%, 70%;
		height: initial;
	}

	.kala .page.unlock-your-kala.mobile .kala-hero {
		position: relative;
		background: #5D431B;
		background-image: url("../img/kala-black-friday-2024-hero.jpg");
		background-size: cover;
		background-repeat: no-repeat;
		background-position: 80% 20%;
		padding-bottom: 2rem;
		min-height: 66vw;
		padding: 10vw;
	}
	.kala .page.unlock-your-kala.gift-page.mobile .kala-hero {
		background-image: linear-gradient(66deg, #000000 -20%, rgba(217, 217, 217, 0.00) 60.61%),
		 url("../img/kala-gift-hero.jpg");
		 background-blend-mode: normal;
	}

	.kala .page.unlock-your-kala.mobile .discount-badge {
		width: 10rem;
		max-width: 30vw;
		top: 25%;
	}

	.kala .page.unlock-your-kala .scale-bg {
		top: -70px;
		width: 851px;
		background-size: 150%;
	}

	.kala .page.unlock-your-kala img.title {
		position: relative;
		max-width: 40vw !important;
		height: initial;
		top: 10vw;
		left: 0px;
		padding-left: 0;
	}

	.kala .page.unlock-your-kala .subtitle {
		padding-top: 10vw;
		padding-left: 0;
		font-size: 4vw;
		line-height: 1.2;
		text-shadow: 0 0 1.2rem rgba(0,0,0,.8);
	}

	.kala .page.unlock-your-kala.mobile .hero-info {
		display: flex;
		flex-direction: column;
		align-items: center;
		background: #F3E9E8;
		padding-bottom: 2rem;
	}

	.kala .page.unlock-your-kala.mobile .points {
		display: grid;
		position: relative;
		width: 100%;
		align-items: center;
		justify-content: space-around;
		row-gap: 0.4rem;
		padding: 1rem 0.8rem;
	}

	.page.unlock-your-kala.mobile .points .point {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: flex-start;
		max-width: 240px;
		font-size: 14px;
		text-align: center;
		color: #333;
		font-weight: 500;
		line-height: 1.5;
		margin-top: 0.3rem;
		padding: 0 .6rem;
		min-height: 5.2rem;
	}

	.page.unlock-your-kala.mobile .points .point .icon {
		margin-bottom: .4rem;
	}	

	.campaign-header {
		margin-top: 84px;
	}

	.campaign-header .cta {
		font-size: 16px;
	}


	.grid00 {
		grid-row: 0;
		grid-column: 0;
	}

	.grid01 {
		grid-row: 1;
		grid-column: 0;
	}

	.grid10 {
		grid-row: 0;
		grid-column: 1;
	}

	.grid10 {
		grid-row: 1;
		grid-column: 1;
	}

	.kala .page.unlock-your-kala.mobile .cta {
		position: relative;
		width: 80%;
		margin: 1rem;
		bottom: initial;
		left: initial;
		right: initial;
		top: initial;
		transform: none;
		height: initial;
	}	

	.kala .page.what-learners-rave-about img.title {
		width: 85vw !important;
        top: 60px;
        left: 24px;
	}

	.kala .page.what-learners-rave-about .testimonial {
		top: 240px;
		left: 52%;
		transform: translate(-45%,0px);
		font-size: 17px;
	}

	.kala .page.what-learners-rave-about .testimonial .quote-mark {
		display: none;
	}	

	.kala .page.what-learners-rave-about .testimonial .quote {
		padding: 3em 1.5em;
	}

	.kala .page.what-learners-rave-about .cta {
		width: 50%;
		min-width: 12rem;
	}

	.kala .page.what-learners-rave-about .testimonial .portrait {
		position: absolute;
		left: -5vw;
		top: -5vw;
		width: 12vw !important;
		height: 12vw !important;
		border-radius: 190px;
		border: 5px solid white;
	}

	.kala .page.learn-and-play-along-step-by-step {
		height: 200px;
	}

	.kala div.page.learn-and-play-along-step-by-step {
		height: 2400px;
		padding: 1rem;
	}
	.kala .page.learn-and-play-along-step-by-step .copy>p {
		font-size: 14px;
	}

	.kala .page.learn-and-play-along-step-by-step img.title {
		width: 85vw !important;
		top: 60px;
		left: 24px;
	}

	.kala .page.learn-and-play-along-step-by-step .copy {
		left: 10px;
		right: 0px;
		width: 100%;
		max-width: 100%;
		padding-left: 5%;
		padding-right: 5%;
		box-sizing: border-box;
		top: 150px;
	}

	.kala .page.learn-and-play-along-step-by-step .whois-hero {
		width: 160vw;
		max-width: 160vw;
		left: -30vw;
		bottom: 20px;
		background-position: center;
	}

	.kala .page.learn-and-play-along-step-by-step .subtitle {
		font-size: 5vw;
	}


	.kala .page.experience-the-magic {
		height: auto;
	}

	.kala .page.experience-the-magic .title {
		top: 0px;
	}

	.kala div.page.learn-and-play-along-step-by-step .journey-steps {
		flex-direction: column;
		width: 100%;
		align-items: center;
		row-gap: 74px;
		margin-top: 620px;
		padding-bottom: 200px;
	}

	.kala .page.learn-and-play-along-step-by-step .journey-steps .step {
		top: 50px;
		width: 14rem;
	} 

	.kala .page.experience-the-magic .journey-steps .step {
		width: 90%;
		max-width: 400px;
	}

	.kala .page.experience-the-magic .journey-steps .step img.portrait {
		width: 100%;
	}

	.kala .page.experience-the-magic .journey-steps .step .number {
		width: 100px;
		height: 100px;
		line-height: 100px;
		font-size: 62px;
	} 	

	.kala .page.experience-the-magic .veil {
		background: rgba(0,0,0,0.8);
	}

	.kala .page.experience-the-magic .cta {
		bottom: 50px;
		width: 50%;
	}

		
	/* Fit for every*/
	.kala .page.fit-for-every-level img.title {
		width: 90vw !important;
	}

	.kala .page.what-are-you-waiting-for {
		background-size: 220%;
	}

	.kala .page.what-are-you-waiting-for img.title {
		width: 85vw !important;
		max-width: 85vw !important;
	}

	.kala .page.what-are-you-waiting-for {
		padding-top: 200px;
		padding-bottom: 180px;
		height: auto;
	}

	.kala .page.what-are-you-waiting-for .reviews {
		position: static;
		transform: none;
		margin: 40px auto;
	}

	.kala .page.page.what-are-you-waiting-for .store-banner {
		width: 65vw;
		max-width: 300px;
		max-height: 100px;
	}


	/* Comparison chart */

	.kala .page.enjoy-unlimited-access .chart,
	.kala .page.enjoy-unlimited-access .chart td {
	  font-size: 0.85rem;
	  padding: 0.3rem;
	}

	#app .form-page h1.title {
		color: #000000;
		font-weight: 700px;
		font-size: 25px;
		line-height: normal;
		max-width: 250px;
	}

	#app>.container .form-page {
		padding-top: 130px;
		background: white;
		min-height: 100vh;
	}

	#app>.container .form-page.onboarding {
		padding-top: 0px;
		justify-content: center;

	}

	#app .form-page .form {
		max-width: 100vw;
		border-radius: 0px;
		padding: 20px;
		background: transparent;
	}

	#app .form-page .form h2 {
		line-height: 1.25;
		font-size: 18px;
		margin-bottom: 8px;
	}

	#app .form-page .distressed {
		display: none;
	}

	#header {
		display: flex;
		justify-content: center;
		align-items: flex-end;
		column-gap: 0px;
		padding: 0px;
	}

	#header>div {
		justify-content: space-between;
		width: 100%;
	}

	#header .logo, #header .lspace {
		display: none;
		flex-shrink: 1;
		min-width: 128px;
	}

	#header .login, #header .account {
		flex-grow: 1;
	}

	#header .login .logo, #header .account .logo, #header .download .logo {
		display: block;
	}

	#header .home .logo, #header .home .lspace {
		display: block;
		flex-grow: 1;
		background-size: contain;
		background-position: left center;
	}

	#header .sweetwater .logo, #header .sweetwater .lspace {
		display: block;
		flex-grow: 1;
		background-size: contain;
		background-position: left center;
	}

	#header .gift .logo, #header .gift .lspace {
		display: block;
		flex-grow: 1;
		background-size: contain;
		background-position: left center;
	}

	#header .offer-1month .logo, #header .offer-1month .lspace {
		display: block;
		flex-grow: 1;
		background-size: contain;
		background-position: left center;
	}
			
	#header .step {
		flex-direction: column;
		row-gap: 8px;
	}

	#header .header-tail {
		font-size: 13px;
		line-height: 1.4;
		padding-left: 16px;
		padding-right: 16px;
		justify-content: stretch;
		column-gap: 0px;
	}

	#header .header-tail .text {
		max-width: 92%;
		padding-left: 1ch;
		padding-right: 1ch;
	}

	#header .header-tail .dismiss-cross {
		text-align: right;
		right: 25px;
	}


	.carousel {
	  top: -80px;
	  height: 100%;
	}

	/* enable carousel */
	#app .form-page .purchase-page .pricing-plans::-webkit-scrollbar {
		display: none;
	}

	#app .form-page .purchase-page .pricing-plans {
		overflow-x: scroll;
		-ms-overflow-style: none;
		scrollbar-width: none;
		justify-content: left;
		touch-action: none;
		padding-right: 40px;
	}

	#app .form-page .purchase-page .selectors {
		display: flex;
		flex-direction: row;
		justify-content: center;
	}

	#app .form-page .purchase-page .price-info {
		min-width: 340px;
		margin: 0 18px;
	}

	#app .form-page .purchase-page .price-info {
		margin: 0 -16px;
	}
	#app .form-page .purchase-page ul.bullets {
		font-size: 13px;
		line-height: 1.4;
	}

	#app .form-page .purchase-page ul.bullets li {
		margin-top: .3em;
		margin-bottom: .3em;
	}
	#app .form-page .purchase-page ul.bullets li:before {
		margin-top: .4em;
	}

	#app .form-page .purchase-page {
		transform: scale(1.0);	
	}
	
	#app .form-page .purchase-page .pricing-plans > div:first-child {
		margin-left: 1rem;
	}

	#app .form-page .purchase-page .pricing-plans {
		padding-right: 1rem;
		padding-top: 1rem;
	}

	#app .form-page .purchase-page .pricing-plans .price-info {
		transition: all .5s;
	}

	#app .form-page .purchase-page .pricing-plans .price-info.price-highlight {
		transform: scale(0.9);
	}

	/* TEMP: test of highlighting centered price */
	#app .form-page .purchase-page .pricing-plans .price-info.selected {
		/* background-color: rgba(255,0,0,0.1); */
		transform: scale(1.0);
		z-index: 2;
		opacity: 1;
		box-shadow: 0 0 1rem rgba(0,0,0,.3);
	}


	#app .form-page .purchase-page .price-info {
		min-width: 280px;
	}

	#app .form-page .purchase-page ul.bullets {
		margin-top: .2rem;
		margin-bottom: .4rem;
	}

	#app .form-page .purchase-page .price-info>.space-between {
	}

	#app .form-page .purchase-page .price-info .baseline .period {
		display: none;
	}

	#app .form-page .purchase-page .price-info .period {
		font-size: 16px;
	}

	#app .form-page .purchase-page .price-info .normal .price {
		font-size: 22px;
	}

	#app .form-page .purchase-page .price-info .price {
		margin-top: .6rem;
	}

	#app .form-page .purchase-page .price-info .total {
		font-size: 80%;
	}

	#app #account .form-page h2 {
		text-align: center;
		width: 100%;
	}

	#app .form-page .purchase-page .price-info .total {
		display: none;
	}

	#app .form-page .purchase-page .price-info .discount-badge {
		top: -20px;
	}

	#app .form-page .free-trial{
		opacity: 0;
	}

	#app .form-page div.qr-code {
		padding: 25px 26px;
	}

	
	#cookie-consent .footer {
		display: flex;
		flex-direction: column;
		padding: 8px;
		text-align: center;
		row-gap: 4px;
	}

}
	
	
@media only screen and (max-width: 480px) {
	#header .cta {
		font-size: .9rem;
		padding: 0px 12px;
	}


	.campaign-header {
		margin-top: 78px;
		padding: .3rem;
	}

	.campaign-header p {
		font-size: 14px;
	}


	#header > div {
		column-gap: .4rem;
	}

	#header .gift .logo,
	#header .lspace {
		min-width: 100px;
	}

	.cta,
	form input[type=submit] {
		font-size: 18px;
		padding: 0px 16px;
	}

	#app .form-page .purchase-page .pricing-plans .price-info,
	#app .form-page .purchase-page .pricing-plans .price-info.price-highlight {
		transform: scale(0.82);
		margin: 0 -28px;
	}

	#app .form-page .purchase-page .pricing-plans .price-info.selected {
		transform: scale(0.9);		
	}

	.cta, form input[type=submit] {
		font-size: 18px;
		padding: 0px 16px;
	}

}

@media only screen and (max-width: 320px) {

	#app .form-page .purchase-page .price-info {	
		padding: 22px;
	}
	#app .form-page .purchase-page .price-info > h3 {	
		margin-top: -23px;
		margin-left: -23px;
		margin-right: -23px;
	}
	#app .form-page .purchase-page .pricing-plans {
		padding-top: 40;
		transform: translateY(-30px);
	}

	#app .form-page .purchase-page .pricing-plans .price-info,
	#app .form-page .purchase-page .pricing-plans .price-info.price-highlight {
		transform: scale(0.72);
		margin: 0 -40px;
	}

	#app .form-page .purchase-page .pricing-plans .price-info.selected {
		transform: scale(0.8);		
	}
	.campaign-header p {
		font-size: 12px;
	}


}


