:root {
	font-size: 16px;
	font-family: "Noto Sans", sans-serif;
	--black: #000000;
	/* Green */
	--white: #ffffff;
	/* Light Gray */
	--grey: #dfdfdf;
	/* Dark Gray */
}

.heading-light {
	font-family: "Noto Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 300;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.heading-regular {
	font-family: "Noto Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.heading-semibold {
	font-family: "Noto Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.heading-extrabold {
	font-family: "Noto Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 900;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.text-light {
	font-family: "Open Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 300;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.text-regular {
	font-family: "Open Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.text-semibold {
	font-family: "Open Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}

.text-extrabold {
	font-family: "Open Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 800;
	font-style: normal;
	font-variation-settings:
		"wdth" 100;
}


.diagonal-lines {
	background: repeating-linear-gradient(45deg,
			#f0f0f0,
			#f0f0f0 15px,
			#ffffff 15px,
			#ffffff 30px);
	opacity: 0.5;
}


* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

a {
	text-decoration: none;
	color: var(--black);
}

ul {
	list-style-type: none;
}

.section {
	max-width: 1200px;
	margin: 0 auto;
}

.pagination {
	padding: 2rem;
	
}

.pagination > a {
	border-bottom: 1px solid #e2e2e2;
}

.pagination > a, 
.pagination > span {
	font-size: 0.9rem;
}

.pagination > a:hover {
	border-bottom: 1px solid #000;
}

.header {
	padding: 1rem 2rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.logo-text>span {
	display: inline-block;
}

.with-icon {
	width: 2.5rem;
	height: 2.5rem;
}

.with-icon img {
	width: 100%;
	height: 100%;
	border: 2px solid #ffd200;
	border-radius: 0.8rem;
}

.notification-message {
	font-size: 0.9rem;
	padding: 0.5rem 1rem;
	text-align: center;
	/* border: 1px solid #e2e2e2; */
	width: fit-content;
	margin: 0 auto;
	border-radius: 0.5rem;
	margin-top: 1.5rem;
	background-color: #fff9dd;
}

.bottom-promotion {
	position: fixed;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 1000;
	background-color: #ffe06f;
	padding: 1rem;
}

.bottom-promotion>p {
	text-align: center;
	font-size: 1rem;
}

.bottom-promotion>p>a {
	color: #195f94;
}


.hero {
	padding: 2rem;
	display: flex;
	justify-self: space-between;
}

.hero-body {
	width: 60%;
}

.hero-side {
	width: 40%
}

.width-50 {
	width: 50%;
}


.hero-title {
	font-size: 4.5rem;
	margin-bottom: 1rem;
}

.hero-subtitle {
	font-size: 1.3rem;
	line-height: 1.8rem;
	margin-bottom: 2rem;
}

.cta-links {
	margin: 0;
}

.btn {
	display: inline-block;
	border: 1px solid var(--black);
	padding: 1rem 2rem;
	border-radius: 0.5rem;
	margin-right: 1rem;
	font-size: 1rem;
}

.btn-primary {
	background-color: #ffe06f;
	border-color: #ffe06f;
	color: #703a0b;
}

.btn-regular {
	background-color: var(--white);
	border-color: #ccc;
}

.menu-container {
	padding: 1rem 2rem;
	border-top: 1px solid #e2e2e2;
}

.menu {
	display: flex;
	gap: 1.5rem;
}

.menu-item-counter {
	display: inline-block;
    padding: 0 0.5rem;
    background: yellow;
	font-size: 0.8rem;
	border-radius: 1rem;
	margin-left: 0.3rem;
}

.menu-item-active {
	border-color: #000 !important;
}

.blocks-container {
	padding: 2rem;
	display: flex;
	gap: 2rem;
	justify-content: space-between;
}

.main-block {
	width: 70%;
}

.side-block {
	width: 30%;
}

.list-items {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin-top: 2rem;
}

.list-item-main-block {
	padding: 0.5rem 1rem;
}

.list-item-main-block > p {
	font-size: 0.8rem;
	padding: 0.3rem 0;
}

.list-item-sub-block {
	display: flex;
	gap: 1rem;
	padding: 0.3rem 1rem;
	border-top: 1px solid #e2e2e2;
	border-radius: 0 0 0.5rem 0.5rem;
}


.list-item-sub-block > p {
	font-size: 0.9rem;
	font-variant: small-caps;
}


.list-item-30 {
	width: calc(33.333% - 1rem);
	border: 1px solid #e2e2e2;
	border-radius: 0.5rem;
	/* padding: 0.5rem 1rem; */

}

.list-item-50 {
	width: calc(50% - 1rem);
	border: 1px solid #e2e2e2;
	border-radius: 0.5rem;
	/* padding: 0.5rem 1rem; */
}

.list-item-50>p,
.list-item-30>p {
	font-size: 0.8rem;
	padding: 0.3rem 0;
}

.list-item-links {
	display: flex;
	gap: 1rem;
	padding: 0.3rem 0;
}

.list-item-link {
	font-size: 0.8rem;
	color: #195f94;
}

.side-block {
	margin-top: 2rem;
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.filters-container {
	padding: 1rem;
	border: 1px solid #e2e2e2;
	border-radius: 0.5rem;
	font-size: 0.8rem;
}

.filter-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-top: 0.5rem;
}

.filter-item > a {
	text-transform: capitalize;
}

.filter-item > a,
.list-item-title {
	border-bottom: 1px solid #e2e2e2;
}

.filter-item > a:hover,
.list-item-title:hover {
	border-bottom: 1px solid #000000;
}


.form-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-bottom: 1rem;
}

.form-group label {
	font-size: 0.9rem;
	font-weight: 600;
	color: #333;
}

.form-input {
	width: 100%;
	font-size: 1rem;
	padding: 0.5rem;
	border: 1px solid #e2e2e2;
	border-radius: 0.5rem;
	font-family: "Open Sans", sans-serif;
}


textarea {
	resize: vertical;
}

input::placeholder,
textarea::placeholder {
  color: #797979;
  font-style: italic;
  font-size: 0.8em;
}

input:: -webkit-input-placeholder,
textarea:: -webkit-input-placeholder {
  color: #797979;
  font-style: italic;
  font-size: 0.8em;
}

input:: -moz-placeholder,
textarea:: -moz-placeholder, {
  color: #797979;
  font-style: italic;
  font-size: 0.8em;
  opacity: 1;
}

input:-moz-placeholder,
textarea:-moz-placeholder {
  color: #797979;
  font-style: italic;
  font-size: 0.8em;
  opacity: 1;
}

input:-ms-input-placeholder,
textarea:-ms-input-placeholder {
  color: #797979;
  font-style: italic;
  font-size: 0.8em;
}

.form-error {
	color: #721c24;
	font-size: 0.8rem;
}

.alert {
	width: 100%;
    font-size: 0.8rem;
    padding: 1rem;
    margin-bottom: 2rem;
	border-radius: 0.5rem;
}

.alert-success {
	background-color: #d4edda;
	color: #155724;
}

.alert-error {
	background-color: #f8d7da;
	color: #721c24;
}


.contribution-message {
	width: 100%;
	font-size: 0.9rem;
	border: 1px solid #e2e2e2;
	border-radius: 0.5rem;
	padding: 1rem;
}


/* BREAKPOINTS */
/* 1200px */
/* 1024px */
/* 768px */
/* 640px */


@media (max-width: 640px) {

	.notification-message {
		margin: 0.5rem 0 0 0;
		border-radius: 0;
	}

	.hero {
		flex-direction: column;
		margin-bottom: 5rem;
	} 

	.hero-body {
		width: 100%;
	}

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

	.blocks-container {
		flex-direction: column-reverse;
		padding: 1rem;
	}

	.main-block,
	.side-block { 
		width: 100%; 
	}

	.side-block,
	.list-items {
		margin-top: 0;
	}
	
	.list-item-50,
	.list-item-30 {
		width: 100%;
	}

	.menu {
		flex-wrap: wrap;
	}

}