:root
{
	--font-family-text: 'Cardo', serif;
	--font-family-links: 'Didact Gothic', sans-serif;
}

body
{
	padding-top: 203px;
}

/***************************************************************************/
/*                                                                         */
/*                                  FONTS                                  */
/*                                                                         */
/***************************************************************************/

html
{
	font-size: 16px;
}

body
{
	font-family: var(--font-family-text);
}

.nav-link
{
	font-family: var(--font-family-links);
}

@media screen and (min-width: 768px) and (max-width: 991px)
{
	html
	{
		font-size: 18px;
	}
}

@media screen and (min-width: 992px) and (max-width: 1199px)
{
	html
	{
		font-size: 20px;
	}
}

@media screen and (min-width: 1200px)
{
	html
	{
		font-size: 22px;
	}
}

body
{
	font-size: 1rem;
	line-height: 1.6;
}

h1
{
	font-size: 2.5rem;
}

h2
{
	font-size: 2rem;
}

h3
{
	font-size: 1.75rem;
}

h4
{
	font-size: 1.5rem;
}

h5
{
	font-size: 1.25rem;
}

h6
{
	font-size: 1rem;
}

p
{
	font-size: 1rem;
}

/***************************************************************************/
/*                                                                         */
/*                              NAVIGATION BAR                             */
/*                                                                         */
/***************************************************************************/

.navbar
{
	padding-top: 15px;
	padding-bottom: 15px;

	/* Fix the Navigation Bar to the top of the viewport */

	position: fixed;
	z-index: 1030;

	top: 0;
	right: 0;
	left: 0;

	/* Center the Navigation Bar's container */

	justify-content: center !important;

	background-color: #fff;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.navbar .container
{
	max-width: 1200px;

	margin-left: 15px;
	margin-right: 15px;

	padding-right: 15px;
	padding-left: 15px;
}

.navbar .navbar-brand
{
	display: flex;
	align-items: center;
	flex-direction: column;
	text-align: center;
}

.navbar .navbar-brand img
{
	margin-right: 15px;
	height: 80px;
	width: auto;
}

.brand-subtext
{
	font-size: 0.8em;
}

.navbar-toggler-icon
{
	width: 30px;
	height: 30px;
}

.navbar .navbar-collapse .navbar-nav
{
	text-align: center;
}

.navbar .navbar-collapse .navbar-nav .nav-link
{
	font-size: 1.125rem;
	padding: 10px 20px;

	border-radius: 5px;
	transition: color 0.15s ease;
}

@media screen and (min-width: 768px) and (max-width: 991px)
{
	.navbar .navbar-collapse .navbar-nav .nav-link a
	{
		font-size: 1.25rem;
	}
}

@media screen and (min-width: 992px) and (max-width: 1199px)
{
	.navbar .navbar-collapse .navbar-nav .nav-link a
	{
		font-size: 1.375rem;
	}
}

@media screen and (min-width: 1200px)
{
	.navbar .navbar-collapse .navbar-nav .nav-link a
	{
		font-size: 1.5rem;
	}
}

.navbar .navbar-collapse .navbar-nav a.nav-link:hover
{
	color: white;
	background-color: var(--bs-tertiary-color);
}

/***************************************************************************/
/*                                                                         */
/*                              PSYCHOTHERAPY                              */
/*                                                                         */
/***************************************************************************/

#pshycotherapy
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#pshycotherapy .container
{
	max-width: 1200px;

	margin: 0;
	padding: 1.5rem;
}

#pshycotherapy .container>*:last-child
{
	margin-bottom: 0;
}

#pshycotherapy .container blockquote
{
	font-size: 1.25rem;
	font-style: italic;

	margin-bottom: 1rem;

	text-align: center;
}

#pshycotherapy .container blockquote p
{
	font-size: inherit;
}

#pshycotherapy .container .row
{
	margin: 0;
}

@media (max-width: 767.98px)
{
	.first-column
	{
		margin-bottom: 0;
	}
}

#pshycotherapy .container blockquote footer
{
	font-size: 0.625em;

	margin-top: -1rem;
	margin-bottom: 1rem;

	color: var(--color-blockquote-footer);
}

#pshycotherapy .container blockquote footer::before
{
	content: "— ";
}

#pshycotherapy .container>p
{
	text-align: justify;
	text-justify: auto;
}

/***************************************************************************/
/*                                                                         */
/*                       GESTALT THERAPY FOUNDATIONS                       */
/*                                                                         */
/***************************************************************************/

#gestalt-therapy-foundations
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#gestalt-therapy-foundations .container
{
	max-width: 1200px;

	margin: 0;
	padding: 1.5rem;
}

#gestalt-therapy-foundations .container>*:first-child
{
	margin-bottom: 1.5rem;
}

#gestalt-therapy-foundations .container>*:last-child
{
	margin-bottom: 0;
}

#gestalt-therapy-foundations .container .row .col-12
{
	margin-bottom: 1.5rem;
}

#gestalt-therapy-foundations .container .row .card
{
	text-align: center !important;
	height: 100% !important;

	/* Flexbox for better alignment */

	display: flex;
	flex-direction: column;
	justify-content: center;
}

#gestalt-therapy-foundations .container .row .card .card-body
{
	margin-top: 0px;
	padding: 1rem;

	/* Flexbox within card body */

	display: flex;
	flex-direction: column;
	align-items: center;
}

#gestalt-therapy-foundations .container .row .card .card-body .card-icon
{
	margin-top: 0px;
	margin-bottom: 1rem;
	font-size: 3rem;
}

#gestalt-therapy-foundations .container .row .card .card-body .card-title
{
	margin-bottom: 0.5rem;
	font-weight: bold;
}

#gestalt-therapy-foundations .container .row .card .card-text
{
	margin-bottom: 1rem;
	font-size: 1rem;
}

#gestalt-therapy-foundations .container>p
{
	text-align: justify;
	text-justify: auto;
}

/***************************************************************************/
/*                                                                         */
/*                                 ABOUT ME                                */
/*                                                                         */
/***************************************************************************/

#about-me
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#about-me .container
{
	max-width: 1200px;

	margin: 0;
	padding: 1.5rem;
}

#about-me .container>*:first-child
{
	margin-bottom: 1.5rem;
}

#about-me .container>*:last-child
{
	margin-bottom: 0;
}

#about-me .container .paragraph
{
	margin-top: 0;
}

#about-me .container .paragraph h6
{
	margin-bottom: 1rem;
}

#about-me .container .paragraph>p
{
	text-align: justify;
	text-justify: auto;
}

#about-me .container .paragraph>*:last-child
{
	margin-bottom: 0;
}

#about-me .container .row .col-12
{
	margin-bottom: 1.5rem;
}

#about-me .container .row .card
{
	text-align: center !important;
	height: 100% !important;
}

#about-me .container .row .card .card-body
{
	margin-top: 0px;
}

#about-me .container .row .card .card-body .card-emoji
{
	margin-top: 0px;
	font-size: 2rem;
}

#about-me .container .row .card .card-body .card-title
{
	margin-bottom: 0px;
}

.image-container
{
	float: right;
	width: 300px;
	margin-left: 15px;
	margin-bottom: 1.5rem;
}

@media (max-width: 767.98px)
{
	.image-container
	{
		float: none;
		width: 100%;
		max-width: 400px;
		margin-left: auto;
		margin-right: auto;
		margin-bottom: 1.5rem;
		text-align: center;
		/* Center the image for smaller screens */
	}

	.image-container .card
	{
		display: inline-block;
		/* Center the card */
	}
}

/***************************************************************************/
/*                                                                         */
/*                                RESOURCES                                */
/*                                                                         */
/***************************************************************************/

#resources
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#resources .container
{
	max-width: 1200px;

	margin-top: 15px;
	margin-bottom: 15px;
	margin-left: 15px;
	margin-right: 15px;

	padding-right: 15px;
	padding-left: 15px;
}

#resources .container>div:first-of-type
{
	margin-top: 1rem;
	margin-bottom: 1rem;
}

#resources .container .accordion .accordion-collapse .accordion-body .list-group .list-group-item
{
	display: flex !important;
	justify-content: space-between !important;
	align-items: center !important;
}

#resources .container .accordion .accordion-collapse .accordion-body .list-group .list-group-item>div>*
{
	margin-bottom: 0.25rem !important;
}

#resources .container .accordion .accordion-collapse .accordion-body .list-group .list-group-item>div>p>span
{
	margin-right: 0.25rem !important;
}

.resource-name-subtext
{
	font-size: 0.8em;
	color: gray;
	font-style: italic;
}

.list-group-item:first-child
{
	border-top-left-radius: 0;
}

.nav-tabs
{
	border-bottom: 0;
}

.accordion-button:focus
{
	outline: none;
	box-shadow: none;
}

/***************************************************************************/
/*                                                                         */
/*                                 CONTACT                                 */
/*                                                                         */
/***************************************************************************/

#contact
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#contact .container
{
	max-width: 1200px;

	margin-top: 15px;
	margin-bottom: 15px;
	margin-left: 15px;
	margin-right: 15px;

	padding-right: 15px;
	padding-left: 15px;
}

#contact .container>div:first-of-type
{
	margin-top: 1rem;
}

#contact .container form .row .col-lg-4,
#contact .container form .row .col,
#contact .container form button
{
	margin-bottom: 1rem;
}

#contact .container form .row input,
#contact .container form .row textarea
{
	margin-top: 0.5rem;
}

.invalid-feedback
{
	display: none;
}

textarea
{
	resize: none;
}

/***************************************************************************/
/*                                                                         */
/*                                   MAP                                   */
/*                                                                         */
/***************************************************************************/

#themap
{
	/* Center items vertically and horizontally */

	display: flex !important;
	align-items: center !important;
	justify-content: center !important;

	text-align: left !important;
}

#themap .container
{
	max-width: 1200px;

	margin-top: 15px;
	margin-bottom: 15px;
	margin-left: 15px;
	margin-right: 15px;

	padding-right: 15px;
	padding-left: 15px;
}

#map
{
	height: 500px;
	width: 100%;
}

/***************************************************************************/
/*                                                                         */
/*                                 FOOTER                                  */
/*                                                                         */
/***************************************************************************/

footer
{
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	flex-direction: column;
	text-align: center;
}

footer .container
{
	max-width: 1200px;
	margin: 1.5rem;
	padding: 1.5rem;
}

footer .contact-info
{
	display: flex;
	justify-content: space-between;
	margin-bottom: 1rem;
}

footer .contact-info .phone-number
{
	text-align: left;
}

footer .contact-info .email-address
{
	text-align: right;
}

footer .contact-info span
{
	margin-right: 0.25rem !important;
}

footer hr
{
	width: 100%;
	border: 0.5px solid #ccc;
	margin-bottom: 1rem;
}

footer .container p
{
	margin-bottom: 0;
}
