/* ============================
	GOSALON LANDERS 2026
	RESPONSIVE
============================ */



/* ============================
	MIN WIDTH 1600PX
============================ */

@media (min-width: 1600px) {

	.hero--content {
		max-width: 1040px;
	}

	.hero--title {
		font-size: 4.8rem;
	}

	.hero--subtitle {
		font-size: 1.9rem;
	}
}



/* ============================
	MAX WIDTH 1399.98PX
============================ */

@media (max-width: 1399.98px) {

	.hero--title {
		font-size: 3.85rem;
	}

	.hero--subtitle {
		font-size: 1.55rem;
	}

	.intro--title,
	.location--title,
	.products--title,
	.reviews--title,
	.gallery--title,
	.treatments--title {
		font-size: 2.15rem;
	}

	.cta--content h2 {
		font-size: 1.9rem;
	}
}



/* ============================
	MAX WIDTH 1199.98PX
============================ */

@media (max-width: 1199.98px) {

	.section--intro,
	.section--treatments,
	.section--products,
	.section--gallery,
	.section--location,
	.section--contact,
	.section--reviews,
	.section--cta,
	.section--footer {
		padding-bottom: 4.5rem;
		padding-top: 4.5rem;
	}

	.section--hero {
		min-height: 92vh;
		padding-top: 7.5rem;
	}

	.hero--container {
		padding-top: 3.5rem;
	}

	.hero--content {
		max-width: 760px;
		padding-left: .5rem;
		padding-right: .5rem;
		top: .5rem;
	}

	.hero--brand img {
		height: 94px;
	}

	.hero--title {
		font-size: 3.15rem;
	}

	.hero--subtitle {
		font-size: 1.35rem;
	}

	.hero--text {
		font-size: 1.05rem;
		max-width: 680px;
	}

	.hero--scroll {
		display: none;
	}

	.intro--features {
		grid-template-columns: 1fr;
	}

	.contact--details {
		padding-right: 0;
	}

	.cta--content {
		padding: .5rem 0 0 0;
	}

	.footer--logo img {
		height: 76px;
	}
}



/* ============================
	MAX WIDTH 991.98PX
============================ */

@media (max-width: 991.98px) {

	.nav--wrapper {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.nav--logo img {
		height: 48px;
	}

	.section--hero {
		min-height: auto;
		padding-bottom: 5rem;
		padding-top: 7rem;
	}

	.hero--content {
		max-width: 760px;
		padding-left: .5rem;
		padding-right: .5rem;
	}

	.hero--brand {
		margin-bottom: 1rem;
	}

	.hero--brand img {
		height: 84px;
	}

	.hero--eyebrow {
		font-size: .76rem;
		gap: .5rem;
		letter-spacing: .06rem;
		margin-bottom: 1rem;
	}

	.hero--title {
		font-size: 2.75rem;
		line-height: 1.02;
	}

	.hero--subtitle {
		font-size: 1.2rem;
		margin-bottom: 1rem;
	}

	.hero--text {
		font-size: 1rem;
		line-height: 1.75;
	}

	.hero--actions .button {
		min-height: 54px;
		padding: .9rem 1.3rem;
	}

	.hero--labels {
		gap: .6rem;
		margin-top: 1.65rem;
	}

	.hero--label {
		font-size: .9rem;
		padding: .65rem .9rem;
	}

	.intro--title,
	.location--title,
	.products--title,
	.reviews--title,
	.gallery--title,
	.treatments--title,
	.contact--title {
		font-size: 2rem;
	}

	.treatment--item {
		padding: 1.05rem 1.1rem;
	}

	.treatment--heading h3 {
		font-size: 1.08rem;
	}

	.treatment--answer {
		padding-right: 2.35rem;
	}

	.product--panel {
		padding: 1.2rem;
	}

	.product--content h3 {
		font-size: 1.3rem;
	}

	#map {
		height: 420px;
	}

	.form--content {
		padding: 1.6rem;
	}

	.review--card {
		padding: 1.2rem 1.2rem 1.25rem 1.2rem;
	}

	.cta--panel {
		padding: .85rem;
	}

	.cta--content h2 {
		font-size: 1.75rem;
	}
}



/* ============================
	MAX WIDTH 767.98PX
============================ */

@media (max-width: 767.98px) {

	.section--intro,
	.section--treatments,
	.section--products,
	.section--gallery,
	.section--location,
	.section--contact,
	.section--reviews,
	.section--cta {
		padding-bottom: 4rem;
		padding-top: 4rem;
	}

	.section--footer {
		padding-bottom: 2.25rem;
		padding-top: 2.5rem;
	}

	.floating--actions {
		bottom: 1rem;
		gap: .6rem;
		right: 1rem;
	}

	.floating--button--booking {
		font-size: .95rem;
		padding: .75rem 1rem;
	}

	.floating--button--whatsapp {
		font-size: 1.35rem;
		height: 48px;
		width: 48px;
	}

	.section--hero {
		padding-bottom: 4rem;
		padding-top: 6.75rem;
	}

	.hero--container {
		padding-bottom: 1.5rem;
		padding-top: 2.5rem;
	}

	.hero--brand img {
		height: 72px;
	}

	.hero--eyebrow {
		font-size: .72rem;
		justify-content: center;
		line-height: 1.4;
	}

	.hero--eyebrow span:not(:last-child)::after {
		display: none;
	}

	.hero--title {
		font-size: 2.3rem;
		letter-spacing: -.03rem;
	}

	.hero--subtitle {
		font-size: 1.08rem;
		line-height: 1.3;
	}

	.hero--text {
		font-size: 1rem;
		line-height: 1.75;
	}

	.hero--actions {
		gap: .8rem;
		margin-top: 1.5rem;
	}

	.hero--actions .button {
		width: 100%;
	}

	.hero--labels {
		gap: .6rem;
		margin-top: 1.6rem;
	}

	.hero--label {
		font-size: .88rem;
		padding: .72rem .9rem;
	}

	.intro--title,
	.location--title,
	.products--title,
	.reviews--title,
	.gallery--title,
	.treatments--title,
	.contact--title {
		font-size: 1.8rem;
		letter-spacing: -.02rem;
	}

	.intro--text,
	.products--intro,
	.gallery--intro,
	.location--intro,
	.reviews--intro,
	.treatments--intro,
	.contact--text,
	.cta--content p {
		font-size: 1rem;
		line-height: 1.75;
	}

	.intro--feature {
		padding: 1.2rem;
	}

	.intro--feature--icon {
		flex: 0 0 46px;
		height: 46px;
		width: 46px;
	}

	.treatment--item+.treatment--item {
		margin-top: .85rem;
	}

	.treatment--heading h3 {
		font-size: 1rem;
		line-height: 1.35;
	}

	.treatment--icon {
		flex: 0 0 1.9rem;
		height: 1.9rem;
		width: 1.9rem;
	}

	.treatment--answer {
		padding-right: 0;
	}

	.product--panel {
		padding: 1rem;
	}

	.product--content h3 {
		font-size: 1.2rem;
		margin-bottom: .65rem;
	}

	.gallery--splide {
		padding-left: 0;
		padding-right: 0;
	}

	.gallery--splide .splide__arrow {
		height: 2.25rem;
		width: 2.25rem;
	}

	#map {
		height: 340px;
	}

	.location--address,
	.location--actions {
		text-align: center;
		width: 100%;
	}

	.contact--actions {
		display: flex;
		flex-direction: column;
		width: 100%;
	}

	.contact--actions .button {
		justify-content: center;
		width: 100%;
	}

	.form--content {
		padding: 1.25rem;
	}

	.form--privacy {
		font-size: .9rem;
	}

	.button--submit {
		width: 100%;
	}

	.review--head {
		gap: .75rem;
		margin-bottom: .85rem;
	}

	.review--avatar {
		flex: 0 0 42px;
		font-size: 1.3rem;
		height: 42px;
		width: 42px;
	}

	.review--quote {
		font-size: 1.2rem;
	}

	.cta--panel {
		padding: .75rem;
	}

	.cta--content h2 {
		font-size: 1.55rem;
		line-height: 1.1;
		margin-bottom: .75rem;
	}

	.cta--content .btn-group {
		display: flex;
		flex-direction: column;
		width: 100%;
	}

	.cta--content .button {
		justify-content: center;
		width: 100%;
	}

	.footer--menu,
	.footer--legal--menu {
		flex-direction: column;
		gap: .7rem;
	}

	.footer--logo img {
		height: 68px;
	}
}



/* ============================
	MAX WIDTH 575.98PX
============================ */

@media (max-width: 575.98px) {

	.section--hero {
		padding-bottom: 3.5rem;
		padding-top: 6rem;
	}

	.hero--content {
		padding-left: 0;
		padding-right: 0;
	}

	.hero--brand img {
		height: 64px;
	}

	.hero--title {
		font-size: 2.05rem;
	}

	.hero--subtitle {
		font-size: 1rem;
	}

	.hero--text {
		font-size: .96rem;
	}

	.hero--labels {
		flex-direction: column;
	}

	.hero--label {
		justify-content: center;
		width: 100%;
	}

	.intro--title,
	.location--title,
	.products--title,
	.reviews--title,
	.gallery--title,
	.treatments--title,
	.contact--title {
		font-size: 1.6rem;
	}

	.intro--feature {
		flex-direction: column;
		gap: .85rem;
		text-align: left;
	}

	.treatment--item {
		padding: 1rem;
	}

	.treatment--question {
		align-items: flex-start !important;
	}

	.treatment--heading h3 {
		padding-top: .1rem;
	}

	.treatment--answer p,
	.product--content p,
	.review--body p {
		font-size: .96rem;
	}

	.location--map--outer,
	.location--map--inner,
	.form--outer,
	.cta--panel {
		border-radius: 1.2rem;
	}

	#map {
		height: 300px;
	}

	.form--content {
		padding: 1rem;
	}

	.review--card {
		padding: 1rem 1rem 1.1rem 1rem;
	}

	.review--meta h3 {
		font-size: .98rem;
	}

	.review--meta span {
		font-size: .9rem;
	}

	.cta--content h2 {
		font-size: 1.45rem;
	}

	.footer--base p {
		font-size: .9rem;
	}
}