/** GLOBAL CSS **/
.ry-bg-section, .ry-bg-section img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
body .ry-text p {
    font-size: 20px !important;
}
body .ry-headline h2 {	
	font-size: clamp(1.875rem, 1.5404rem + 1.3725vw, 3.1875rem);
	letter-spacing: -2px;
	color: #744b37;
	font-family: "Garvis Pro";
	text-transform: capitalize;
	line-height: 1.1;
}
body .ry-headline h3 {
    font-size: clamp(1.5rem, 1.4363rem + 0.2614vw, 1.75rem);
	letter-spacing: -1px;
	color: #887f6e;
	font-style: italic;
	font-family: "Garvis Pro";
	line-height: 1.1;
}
body .ry-headline h4 {	
	font-size: 20px;
	letter-spacing: 4px;
	text-transform: uppercase;
	color: #877e6e;
	line-height: 1.1;
}
body .ry-container-1280 {
    max-width: 1280px;
    width: 90%;
	float: none;
	margin: 0 auto;
}
body .ry-headline {
    margin-bottom: 2vw;
}
/** END GLOBAL CSS **/

/** HERO SECTION **/
.ry-ip-hero {
    position: relative;
    height: calc(100vh - 70px);
    display: flex;
    align-items: center;
    justify-content: center;
}
.ry-ip-hero-banner {
    display: flex;
    flex-direction: column;
    gap: 20px;
    justify-content: center;
    align-items: center;
	max-width: 800px;
	width: 100%;
}
.ry-ip-hero-banner .ry-logo-wrapper {
    max-width: 124px;
}
.ry-ip-hero-banner .ry-btn-wrap a.ry-btn:before {
    content: "\f0f0";
    font-size: 18px;
    font-family: 'FontAwesome';
    color: #fff;
    display: inline-block;
    margin-right: 5px;
}
.ry-ip-hero-banner a.ry-btn.ry-btn-secondary:before {
    content: "\f133";
}
.ry-ip-hero-banner a.ry-btn.ry-btn-primary {
    background: #734b35 !important;
}
.ry-ip-hero-banner a.ry-btn.ry-btn-secondary {
    background: #91795b !important;
}
.ry-ip-hero-banner a.ry-btn.ry-btn-primary:hover {
    background: #91795b !important;
}
.ry-ip-hero-banner a.ry-btn.ry-btn-secondary:hover {
    background: #734b35 !important;
}
.ry-ip-hero .ry-ip-headline h1 {
    font-size: clamp(2.5rem, 1.6238rem + 3.5948vw, 5.9375rem);
    letter-spacing: -2px;
    line-height: 1.1;
    text-align: center;
}
.ry-ip-hero .ry-ip-headline h4 {
    font-size: clamp(1.25rem, 1.2022rem + 0.1961vw, 1.4375rem);
    letter-spacing: 7px;
    text-transform: uppercase;
    text-align: center;
}

/** SPECIALTY SECTION **/
.ry-ip-specialist {
    padding: 6vw 0;
    position: relative;
}
.ry-ip-specialist .ry-flex {
    align-items: center;
    gap: 4em;
}
.ry-ip-specialist .ry-container {
    max-width: 1280px;
    width: 90%;
}
.ry-ip-specialist .ry-flex .ry-each.ry-img-wrap img {
    max-width: 470px;
    margin: 0 auto;
}

/** REFER SECTION **/
.ry-ip-refer {
    padding: 4vw 0;
    background: #f4f2ee;
    position: relative;
}
.ry-ip-refer:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 37%;
    background: #d9d4c9;
}
.ry-ip-refer .ry-flex {
    flex-wrap: wrap;
    gap: 20px;
	justify-content: center;
}
.ry-ip-refer .ry-flex .ry-each {
    width: 302px;
    border-radius: 20px;
    background-color: #ffffff;
    padding: 35px 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.ry-ip-refer .ry-flex .ry-each .ry-icon-wrapper img {
    max-width: max-content;
    margin: 0 auto 20px;
}
.ry-ip-refer .ry-cta-name h4 {
    font-size: 20px;
    letter-spacing: 0px;
    text-transform: uppercase;
    color: #91795b;
    font-weight: bold;
    line-height: 1.2
}

/** TREATMENT SECTION **/
.ry-ip-treatments {
    padding: 4vw 0 6vw;
    background: #d9d4c9;
    position: relative;
}
.ry-ip-treatments .ry-flex {
    flex-wrap: wrap;
    gap: 20px;
	justify-content: center;
}
.ry-ip-treatments .ry-flex .ry-each {
    width: 628px;
    height: 221px;
    border-radius: 20px;
    background-color: #f4f2ee;
    position: relative;
    padding: 20px 40px;
}
.ry-ip-treatments .ry-flex .ry-each .ry-bg-wrap, 
.ry-ip-treatments .ry-flex .ry-each .ry-bg-wrap img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border-radius: 20px;
    z-index: 1;
}
.ry-ip-treatments .ry-flex .ry-each .ry-blurb-wrap {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    height: 100%;
}
.ry-ip-treatments .ry-flex .ry-each .ry-blurb-wrap h4 {
    font-size: 20px;
    line-height: 1.1;
    letter-spacing: 0px;
    text-transform: uppercase;
    color: #91795b;
    font-weight: bold;
}
.ry-ip-treatments .ry-flex .ry-each .ry-blurb-wrap p {
    line-height: 1.3;
}

/** JOURNEY SECTION **/
.ry-ip-journey {
    padding: 4vw 0;
    position: relative;
}
.ry-ip-journey .ry-content {
    position: relative;
}
.ry-ip-journey .ry-flex {
    flex-wrap: wrap;
}
.ry-ip-journey .ry-flex .ry-each {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.ry-ip-journey .ry-flex .ry-each .ry-dots-wrap {
    margin-top: -70px;
    margin-bottom: 2vw;
}
.ry-ip-journey .ry-flex .ry-each .ry-dots-wrap img {
    max-width: 29px;
    margin: 0 auto;
}
.ry-ip-journey .ry-flex .ry-each .ry-icon-wrapper img {
    max-width: max-content;
    margin: 0 auto;
}
.ry-ip-journey .ry-headline h2 {
    color: #fff;
}
.ry-steps-title * {
    color: #fff;
}
.ry-ip-journey .ry-steps-title h4 {
    font-size: 20px;
    text-transform: uppercase;
    font-weight: bold !important;
    line-height: 1.1;
}
.ry-ip-journey .ry-steps-title p {
    font-size: 15px;
    text-transform: uppercase;
}
/** QUICK & EASY SECTION **/
.ry-ip-quick-and-easy {
    position: relative;
    padding: 4vw 0;
}
.ry-ip-quick-and-easy .ry-flex {
    align-items: center;
    gap: 4em;
}
.ry-ip-quick-and-easy .ry-flex .ry-each:not(.ry-text-wrap) {
    display: flex;
    justify-content: center;
}

.ry-ip-smile-journey {
    padding: 8vw 0;
}
.ry-ip-quick-and-easy .ry-text-wrap *, .ry-ip-smile-journey .ry-text-wrap * {
    color: #fff;
}


/** PLACE YOUR MOBILE AND UP CSS HERE **/
@media (min-width: 1081px) {
	.ry-ip-hero-banner {
		max-width: 800px;
	}
}

@media (max-width: 1080px) {
	.ry-ip-hero-banner {
		max-width: 100%;
	}
	.ry-ip-hero {
		padding-top: 150px;
		height: auto;
		flex-direction: column;
		gap: 2em;
		padding-bottom: 2em;
	}
	.ry-ip-hero .ry-bg-section, .ry-ip-hero .ry-bg-section img {
		position: relative;
	}
	.ry-ip-specialist .ry-flex {
		flex-direction: column;
	}
	.ry-ip-journey .ry-content .ry-blocks,
	.ry-ip-journey .ry-flex .ry-each .ry-dots-wrap {
		display: none;
	}
	.ry-ip-journey .ry-flex {
		gap: 3em;
	}
	.ry-ip-quick-and-easy .ry-flex {
		flex-direction: column;
	}
	.ry-ip-smile-journey .ry-bg-section img {
		opacity: 0.6;
	}
	.ry-btn-wrap {
		margin-top: 0;
	}
}

@media (max-width: 500px) {
	.ry-ip-treatments .ry-flex .ry-each .ry-bg-wrap img {
		opacity: 0.3;
	}
	.ry-ip-treatments .ry-flex .ry-each .ry-blurb-wrap {
		align-items: center;
	}
}