/*! BuildToolsCookbook v2.0.0 | (c) 2023 Your Name | MIT License | http://github.com/cferdinandi/build-tools-boilerplate */
/*@mixin box-shadow ( $top: 0, ) {
	-webkit-box-shadow: inset 0 -0.125rem 0 0 $light-blue;
	-moz-box-shadow: inset 0 -0.125rem 0 0 $light-blue;
	box-shadow: inset 0 -0.125rem 0 0 $light-blue;

	-webkit-box-shadow: inset 0 -0.125rem 0 0 $light-blue;
	-moz-box-shadow: inset 0 -0.125rem 0 0 $light-blue;
	box-shadow: inset 0 -0.125rem 0 0 $light-blue;

}	*/
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	/* 1 */
	-webkit-text-size-adjust: 100%;
	/* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	/* 1 */
	height: 0;
	/* 1 */
	overflow: visible;
	/* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	/* 1 */
	font-size: 1em;
	/* 2 */
}

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	/* 1 */
	text-decoration: underline;
	/* 2 */
	text-decoration: underline dotted;
	/* 2 */
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	/* 1 */
	font-size: 1em;
	/* 2 */
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	/* 1 */
	font-size: 100%;
	/* 1 */
	line-height: 1.15;
	/* 1 */
	margin: 0;
	/* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	/* 1 */
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	/* 1 */
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	/* 1 */
	color: inherit;
	/* 2 */
	display: table;
	/* 1 */
	max-width: 100%;
	/* 1 */
	padding: 0;
	/* 3 */
	white-space: normal;
	/* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
	box-sizing: border-box;
	/* 1 */
	padding: 0;
	/* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
	-webkit-appearance: textfield;
	/* 1 */
	outline-offset: -2px;
	/* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	/* 1 */
	font: inherit;
	/* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

body {
	-ms-word-wrap: break-word;
	word-wrap: break-word;
	font-size: 16px;
}

body,
button,
input,
select,
textarea {
	color: #000000;
	font-family: "PT Sans", sans-serif;
	font-weight: 400;
	font-style: normal;
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
	font-family: "Merriweather", serif;
	font-weight: 400;
	font-style: normal;
	display: block;
	margin: 2rem 0 1rem;
}

h1 {
	font-size: 1rem;
	line-height: 1;
	margin: 0;
}

h2 {
	font-size: 1.5rem;
	line-height: 1.16667;
}

@media (min-width: 55rem) {
	h1 {
		font-size: 1.5rem;
		line-height: 1.16667;
	}

	h2 {
		font-size: 3rem;
		line-height: 1.125;
		margin: 3rem 0 2rem;
	}
}
p {
	margin: 0;
	max-width: 25em;
}

hr {
	margin: 2rem auto;
	border: none;
	height: 3px;
	background: #FFFFFF;
	clear: both;
}

i,
em {
	font-style: normal;
	font-weight: normal;
}
i b, i strong,
em b,
em strong {
	font-style: inherit;
	font-weight: inherit;
}

b,
strong {
	font-weight: 700;
	font-weight: bold;
}
b i, b em,
strong i,
strong em {
	font-style: inherit;
	font-weight: inherit;
}

address {
	margin: 1rem auto;
	padding: 0 1rem;
	text-align: left;
	font-weight: initial;
	font-style: normal;
}

sub,
.subscript {
	font-variant-position: sub;
	-moz-font-feature-settings: "subs";
	-webkit-font-feature-settings: "subs";
	font-feature-settings: "subs";
}

sup,
.superscript {
	font-variant-position: super;
	-moz-font-feature-settings: "sups";
	-webkit-font-feature-settings: "sups";
	font-feature-settings: "sups";
}

abbr,
.abbreviaton,
.smallcaps {
	font-feature-settings: "c2sc", "smcp";
}

.center {
	text-align: center;
}

.blue {
	color: #02023B;
}

.orange {
	color: #FF3D02;
}

.purple {
	color: #66023B;
}

.yellow {
	color: #FFC902;
}

.red {
	color: #A3023B;
}

.green {
	color: #02C9A3;
}

.visually-hidden {
	visibility: none;
}

img {
	height: auto;
	width: 100%;
	display: block;
}

q {
	font-style: inherit;
	font-weight: inherit;
}
q p {
	margin: 0 auto;
}

blockquote {
	font-style: inherit;
	font-weight: inherit;
	line-height: 1.25;
	padding: 0px 25px 20px 0px;
	margin: 50px 20px;
	position: relative;
	overflow: hidden;
}
blockquote p {
	max-width: 720px;
	margin: 25px 0 50px;
	padding: 0;
}

ul, ol {
	margin: 0 0;
	padding: 0;
	max-width: 23.5em;
}

ul, ol {
	list-style: none;
}

li {
	margin: 0;
}

li > ul,
li > ol {
	margin: 0;
}

table {
	margin: 30px auto;
	width: 100%;
	max-width: 35rem;
	table-layout: fixed;
}

tr {
	position: relative;
}
td {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/**
 * @section Base Styles
 */
html {
	box-sizing: border-box;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

html {
	scroll-behavior: smooth;
}

::selection {
	text-shadow: initial;
	color: #66023B;
	background: #FFC902;
}

html, body {
	max-width: 100%;
	overflow-x: hidden;
}

html {
	background: #FAFAFF;
}

dt {
	font-weight: bold;
}

dd {
	margin: 0 24px 24px;
}

embed,
iframe,
object {
	max-width: 100%;
}

figure {
	margin: 0;
	/* Extra wide images within figure tags don't overflow the content area. */
}

table {
	margin: 0 0 1em;
	width: 100%;
}

@media (min-width: 80rem) {
	html:before, html:after {
		width: 80rem;
		padding-bottom: 80rem;
	}
	html:before {
		margin-top: -40rem;
	}
}
header {
	padding: 2rem 2rem 0;
	display: flex;
	justify-content: space-between;
	max-width: 80rem;
	margin: 0 auto;
}

.logo {
	color: #66023B;
	width: auto;
	font-size: 0;
	position: relative;
	padding: 0 0 0 3.25rem;
}
.logo:before, .logo:after {
	position: absolute;
	left: 0;
	content: "";
	border-radius: 50%;
}
.logo:before {
	display: inline-block;
	width: 2.25rem;
	height: 2.25rem;
	background: #66023B;
	margin: 6px 0;
}
.logo:after {
	top: 6px;
	display: block;
	margin: 0.5625rem;
	width: 1.125rem;
	height: 1.125rem;
	background: #FFC902;
	transition: transform linear 0.125s;
}
.logo:hover:after {
	transform: scale(1.25);
}
.logo h1 {
	text-transform: uppercase;
	text-align: center;
	display: inline-block;
	color: #66023B;
}
.logo h1 strong, .logo h1 span {
	display: block;
}

main {
	max-width: 80rem;
	margin: 0 auto;
	display: block;
}

section {
	position: relative;
	padding: 2rem;
	margin: 0 0 4rem;
}

#about {
	color: #66023B;
	position: relative;
}
#about h2 {
	max-width: 12em;
}
#about:before {
	content: "";
	display: block;
	background: white;
	box-shadow: 4px 4px 32px rgba(2, 2, 59, 0.16);
	border-radius: 50%;
	position: absolute;
	bottom: -3rem;
	left: 50%;
	transform: translate(-50%, 0);
	margin: auto;
	z-index: -1;
	width: 250%;
	padding-bottom: 250%;
}

#services {
	color: #A3023B;
}
#services:before {
	content: "";
	display: block;
	background: white;
	box-shadow: 4px 4px 32px rgba(2, 2, 59, 0.16);
	border-radius: 50%;
	position: absolute;
	left: 0;
	right: 0;
	margin: -7% 0 0 -7%;
	z-index: -1;
	width: 85%;
	padding-bottom: 85%;
}
#services h2 {
	max-width: 11em;
}

#contact {
	color: #02023B;
}
#contact:before {
	content: "";
	display: block;
	background: white;
	box-shadow: 4px 4px 32px rgba(2, 2, 59, 0.16);
	border-radius: 50%;
	position: absolute;
	right: 0;
	margin: 0;
	z-index: -1;
	width: 50%;
	padding-bottom: 50%;
}
#contact h2 {
	max-width: 9em;
}

footer {
	color: #66023B;
	position: relative;
	padding: 8rem 2rem 3rem;
	overflow: hidden;
	max-width: 80rem;
	margin: 0 auto;
}
footer:before {
	content: "";
	display: block;
	background: white;
	box-shadow: 4px 4px 32px rgba(2, 2, 59, 0.16);
	border-radius: 50%;
	position: absolute;
	top: 2rem;
	left: 50%;
	transform: translate(-50%, 0);
	margin: auto;
	z-index: -1;
	width: 250%;
	padding-bottom: 250%;
}

@media (min-width: 35rem) {
	section {
		width: 60%;
		margin: 15% 20%;
	}
	section#about {
		margin-top: 0;
	}
	section#services {
		width: 66%;
		margin: 15% 17%;
	}
	section#services:before {
		width: 65%;
		padding-bottom: 65%;
	}

	footer {
		width: 100%;
		padding: 8rem 20% 3rem;
	}
}
@media (min-width: 55rem) {
	.logo {
		padding: 0 0 0 6.25rem;
	}
	.logo:before {
		width: 4.5rem;
		height: 4.5rem;
		margin: 6px 0;
	}
	.logo:after {
		margin: 1.125rem;
		width: 2.25rem;
		height: 2.25rem;
	}
}
@media (min-width: 80rem) {
	section {
		width: 50%;
		margin: 10% 25%;
	}

	footer {
		width: 100%;
		padding: 8rem 20% 3rem;
	}
	footer:before {
		width: 100%;
		padding-bottom: 100%;
	}
}
button,
[type=button],
[type=reset],
[type=submit] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 0;
	cursor: pointer;
}

a {
	clear: both;
	cursor: pointer;
	text-decoration: underline;
	font-style: bold;
	font-weight: 700;
}
a:link, a:visited {
	color: #02023B;
}
a:hover, a:focus, a:active {
	color: #02023B;
	outline: 0;
}

.menu__list {
	max-width: none;
	font-size: 0;
}
.menu__item {
	display: inline-block;
	width: 2.25rem;
	height: 2.25rem;
	border-radius: 50%;
	background: #02023B;
	margin: 6px 0 6px 0.5rem;
}
.menu__item a {
	display: block;
	margin: 0.5625rem;
	width: 1.125rem;
	height: 1.125rem;
	border-radius: 50%;
	background: #FF3D02;
	transition: transform linear 0.125s;
}
.menu__item a:hover {
	transform: scale(1.25);
}
.menu__item:nth-child(1) {
	background: #A3023B;
}
.menu__item:nth-child(1) a {
	background: #02C9A3;
}

.visually-hidden {
	visibility: hidden;
	opacity: 0;
}

@media (min-width: 55rem) {
	.menu__item {
		width: 4.5rem;
		height: 4.5rem;
	}
	.menu__item a {
		margin: 1.125rem;
		width: 2.25rem;
		height: 2.25rem;
	}
}
.clear:before,
.clear:after {
	content: "";
	display: table;
	table-layout: fixed;
}

.clear:after {
	clear: both;
}