.page-title {
    font-family: var(--font-cabin);
    font-weight: 600;
    font-size: 1.5rem;
    line-height: calc(35.5 / 24);
    color: var(--text-color);
    margin: 0 auto 10px;
    padding: 0 20px;
}

.panel-intro:has(.page-title) .page-title {
    padding: 0;
}

.panel-intro .page-title {
    max-width: 100%;
    width: 100%;
}

.page-title.black {
	color: var(--black-alt);
}

.page-title.blue {
	color: var(--dark-blue);
	font-family: var(--font-baloo);
	font-weight: 700;
	font-size: 1.75rem;
} 

.homepage-intro .page-title {
    max-width: calc(100% - 40px);
    width: 100%;
    margin: 0 auto;
    font-weight: 400;
    font-size: 1.375rem;
    line-height: calc(25 / 22);
    text-align: center;
}

@media (min-width: 40em) {
    .page-title {
        max-width: var(--width-base);
        font-size: 2.814rem;
        line-height: calc(66.55 / 45);
        margin-bottom: 20px;
    }
    
    .homepage-intro .page-title {
        font-size: 2.5rem;
        line-height: calc(59.16 / 40);
    }
	.page-title.blue {
		font-size: 2.5rem;
	} 
	
}

@media (min-width: 64em) {
	.page-title.blue {
		font-size: 3.75rem;
	} 
}