
/********************************************************************* BASE ***/

@media (max-width: 768px) {
	html, body {
		width: auto !important;
		overflow-x: hidden !important;
	}
}

@media (min-width: 1920px) {
	.container {
		max-width: 1548px;
	}
}

body, a {
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-weight: 400;
	color: #766666;
	font-size: clamp(1.25rem, 0.375vw + 1.175rem, 1.625rem);
	line-height: clamp(1.675rem, 0.827vw + 1.51rem, 2.503rem);
}

p {
	margin: 0;
	padding: 0;
	margin-bottom: clamp(1.2rem, 0.9600rem + 1.2000vw, 2.4rem);
}

p:last-child {
	margin-bottom: 0;
}

h2 {
	font-family: "Playfair Display", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: clamp(2.375rem, 1.375vw + 2.1rem, 3.75rem);
	line-height: clamp(2.613rem, 1.325vw + 2.348rem, 3.938rem);
	color: #766666;
	margin-bottom: clamp(1.8rem, 1.5200rem + 1.4000vw, 3.2rem);
}

h2 strong, h2 b {
	font-weight: 900;
}

h3 {
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: clamp(1.75rem, 1vw + 1.55rem, 2.75rem);
	line-height: clamp(2.1rem, 1.475vw + 1.805rem, 3.575rem);
	color: #252524;
	margin-bottom: clamp(1.8rem, 1.6600rem + 0.7000vw, 2.5rem);
}

h4 {
	font-family: "Montserrat", sans-serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: clamp(1.313rem, 0.875vw + 1.138rem, 2.188rem);
	line-height: clamp(1.575rem, 1.269vw + 1.321rem, 2.844rem);
	color: #766666;
	margin-bottom: clamp(1.8rem, 1.6600rem + 0.7000vw, 2.5rem);
	padding-top: clamp(1rem, 0.8000rem + 1.0000vw, 2rem);
}

.btn-primary {
	font-family: "Poppins", sans-serif;
	font-style: normal;
	font-weight: 600;
	font-size: 1.1rem;
	padding: 1.2rem 4.4rem;
	border-radius: 3px;
	--bs-btn-color: #faf2e7;
	--bs-btn-bg: #766666;
	--bs-btn-border-color: #766666;
	--bs-btn-hover-color: #FFFFFF;
	--bs-btn-hover-bg: #151515;
	--bs-btn-hover-border-color: #151515;
	--bs-btn-active-color: #FFFFFF;
	--bs-btn-active-bg: #000000;
	--bs-btn-active-border-color: #000000;
	margin-top: 2rem;
	border-radius: 5px;
}

@media (min-width: 768px) {

	.btn-primary {
		font-size: 1.2rem;
		padding: 1.2rem 4.5rem;
	}

}

@media (min-width: 1400px) {

	.btn-primary {
		font-size: 1.5rem;
		padding: 1.2rem 5.6rem;
		font-weight: 700;
	}

}

/******************************************************************* HEADER ***/

.header strong,
.header b {
	font-weight: 900;
}

.header {
	position: relative;
	background-image: none;
	background-position: center top;
	background-repeat: no-repeat;
	background-size: cover;
}

.header .container {
	position: relative;
	height: clamp(48rem, 45.7750rem + 11.1250vw, 59.125rem);
	background-image: none;
	background-position: left bottom;
	background-repeat: no-repeat;
	background-size: contain;
}

.header .container.lower {
	height: clamp(24rem, 18.3000rem + 28.5000vw, 52.5rem);
}

.header .logo {
	display: block;
	text-align: center;
}

.header .logo img {
	width: 100px;
	margin-top: 15px;
	margin-bottom: 25px;
}

.header .slogan {
	margin-bottom: 25px;
	text-align: center;
}

.header .slogan h2 {
	margin-bottom: 10px;
}

.header .slogan span {
	font-size: 1.1em;
	color: #7f94c0;
}

.header .signature {
	text-align: right;
	max-width: 40%;
	float: right;
	color: #7f94c0;
}

.header .signature img {
	width: 120px;
}

.header .signature span {
	display: block;
	font-size: 0.9rem;
	line-height: 1.1;
}

@media (min-width: 768px) {

	.header .container {
		background-position: left bottom;
	}

	.header .logo {
		position: absolute;
		left: 15px;
		top: 20px;
	}

	.header .logo img {
		width: 140px;
	}

	.header .slogan {
		position: absolute;
		right: 15px;
		top: 5%;
		max-width: 70%;
		text-align: right;
	}

	.header .signature {
		position: absolute;
		right: 15px;
		bottom: 60%;
	}

}

@media (min-width: 992px) {

	.header .container {
		background-size: 75%;
	}

	.header .slogan {
		right: 15px;
		top: 20%;
		max-width: 50%;
	}

	.header .signature {
		right: 15px;
		bottom: 40%;
	}

}

@media (min-width: 1200px) {

	.header .container {
		background-size: 80%;
	}

	.header .slogan {
		right: 15px;
		top: 20%;
		max-width: 50%;
	}

	.header .signature {
		right: 15px;
		bottom: 40%;
	}

}

@media (min-width: 1400px) {

	.header .container {
		background-size: 70%;
	}

	.header .logo img {
		width: 180px;
	}

	.header .slogan {
		right: 15px;
		top: 20%;
		max-width: 50%;
	}

	.header .slogan h2 {
		margin-bottom: 30px;
		font-size: 2.6em;
	}

	.header .signature {
		right: 15px;
		bottom: 20%;
	}

	.header .signature img {
		width: 220px;
	}

	.header .signature span {
		display: block;
		font-size: 1.2rem;
		line-height: 1.1;
	}

}

@media (min-width: 1920px) {

	.header .container {
		background-size: 66%;
	}

	.header .logo img {
		width: 220px;
		margin-top: 50px;
	}

	.header .slogan {
		right: 15px;
		top: 25%;
		max-width: 50%;
	}

	.header .slogan h2 {
		margin-bottom: 40px;
		font-size: 2.9em;
		line-height: 1;
	}

	.header .slogan span {
		font-size: 1.4em;
	}

	.header .signature {
		right: 15px;
		bottom: 11%;
	}

	.header .signature img {
		width: 290px;
	}

	.header .signature span {
		display: block;
		font-size: 1.25rem;
		line-height: 1.1;
	}

}

.header .krivulja {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
}

.header .krivulja img {
	width: 100%;
	height: auto;
	vertical-align: bottom;
}

/**************************************************************** MAIN MENU ***/

.header .mainmenu {
	position: absolute;
	right: 0;
	top: 35px;
}

.header .mainmenu a {
	float: left;
	text-transform: uppercase;
	text-decoration: none;
	margin-right: 38px;
	font-weight: 500;
	font-size: 18px;
}

.header .mainmenu a:last-child {
	margin-right: 0;
}

.header .mainmenu a:hover {
	color: #000000;
}

.header .mainmenu a.active {
	font-weight: bold;
}

.header .mainmenu a img {
	height: 16px;
	vertical-align: middle;
	margin-right: 10px;
	margin-top: -4px;
}

@media (max-width: 991px) {

	.header .mainmenu {
		display: none;
	}

}

/********************************************************* MAIN MENU BURGER ***/

.mainmenu-burger {
	position: absolute;
	right: 15px;
	top: 35px;
}

.mainmenu-burger > a > img {
	height: 26px;
}

.mainmenu-burger .dropdown-menu {
	padding: 10px;
	box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
}

.mainmenu-burger .dropdown-item {
	font-size: 18px;
}

@media (min-width: 992px) {

	.header .mainmenu-burger {
		display: none;
	}

}

@media (min-width: 768px) {

	.mainmenu-burger {
		left: 56px;
		top: 260px;
	}

}

/******************************************************************** INTRO ***/

.intro {
	background-color: #766666;
	margin-bottom: clamp(3rem, 2.3500rem + 3.2500vw, 6.25rem);
}

.intro .container {
	padding-top: clamp(4rem, 3.1750rem + 4.1250vw, 8.125rem);
	padding-bottom: clamp(4rem, 3.1750rem + 4.1250vw, 8.125rem);
}

.intro,
.intro a,
.intro h2 {
	color: #FFFFFF;
}

.intro p:first-of-type {
	font-size: 1.3em;
	line-height: 1.22em;
	margin-bottom: 1.3em;
}

.intro .separator {
	background-color: #FFFFFF;
}

.intro .separator img {
	width: 100%;
	vertical-align: top;
}

@media (min-width: 1200px) {

	.intro h2 {
		max-width: 80%;
	}

}

/***************************************************************** SERVICES ***/

.services .container {
	position: relative;
}

.services ul {
	list-style-type: none;
	padding: 0;
	margin: 0;
	margin-bottom: clamp(3rem, 1.8500rem + 5.7500vw, 8.75rem);
}

.services ul li:nth-child(1) { background-image: url('../images/ik-srce.png'); }
.services ul li:nth-child(2) { background-image: url('../images/ik-roza.png'); }
.services ul li:nth-child(3) { background-image: url('../images/ik-srce-z-roko.png'); }
.services ul li:nth-child(4) { background-image: url('../images/ik-list.png'); }
.services ul li:nth-child(5) { background-image: url('../images/ik-skoljka.png'); }

.services ul li {
	background-position: left center;
	background-repeat: no-repeat;
	background-size: 60px;
	padding: 20px 0 20px 80px;
}

.services .secondary img {
	max-width: 100%;
	margin-bottom: 50px;
}

.services .separator img {
	width: 100%;
	vertical-align: bottom;
}

@media (min-width: 992px) {

	.services ul li {
		background-size: 80px;
		padding: 30px 0 30px 110px;
	}

}

@media (min-width: 1200px) {

	.services .secondary img {
		display: none;
	}

	.services {
		background-image: url('../images/spela-hcerka.png');
		background-position: right 120%;
		background-repeat: no-repeat;
		background-size: 60%;
	} 

}

@media (min-width: 1400px) {

	.services ul li {
		background-size: 110px;
		padding: 40px 0 40px 160px;
	}

}

@media (min-width: 1920px) {

	.services .secondary img {
		display: none;
	}

	.services {
		background-image: url('../images/spela-hcerka.png');
		background-position: right 170%;
		background-repeat: no-repeat;
		background-size: 66%;
	} 

}

@media (min-width: 2500px) {

	.services {
		background-position: right 180%;
		background-size: 50%;
	} 

}

/******************************************************************** ABOUT ***/

.about {
	background-color: #709c96;
	padding-top: clamp(5rem, 3.8200rem + 5.9000vw, 10.9rem);
	margin-bottom: clamp(5rem, 3.8100rem + 5.9500vw, 10.95rem);
}

.about,
.about a,
.about h2,
.about h3 {
	color: #faf2e7;
}

.about .secondary {
	text-align: center;
}

.about .secondary img {
	max-width: 300px;
}

@media (min-width: 1200px) {

	.about > .container > .row {
		--bs-gutter-x: 90px;
		--bs-gutter-y: 0;
	}

	.about .secondary img {
		max-width: 100%;
	}

}

.about .primary p:first-of-type {
	font-size: 1.3em;
	line-height: 1.22em;
	margin-bottom: 1.3em;
}

@media (min-width: 1200px) {

	.about .primary p:first-of-type {
		font-size: 1.4em;
		line-height: 1.32em;
		margin-bottom: 1.4em;
	}
	
}

.about .quote {
	padding-top: clamp(6rem, 4.8250rem + 5.8750vw, 11.875rem);
	padding-bottom: clamp(5rem, 4.0000rem + 5.0000vw, 10rem);
}

.about .quote img {
	max-width: 300px;
}

/************************************************************* TESTIMONIALS ***/

.testimonials {
	margin-bottom: clamp(5rem, 3.8100rem + 5.9500vw, 10.95rem);
}

.testimonials h2 {
	text-align: center;
	margin-bottom: clamp(3rem, 2.4000rem + 3.0000vw, 6rem);
}

.testimonials .row {
	--bs-gutter-x: 30px;
	--bs-gutter-y: 0;
}

.testimonials .box {
	color: #3f4b55;
	font-style: italic;
	background-color: #f8efdd;
	border-radius: 5px;
	padding-left: clamp(2rem, 1.5800rem + 2.1000vw, 4.1rem);
	padding-right: clamp(2rem, 1.5800rem + 2.1000vw, 4.1rem);
	padding-top: clamp(3rem, 2.4750rem + 2.6250vw, 5.625rem);
	padding-bottom: clamp(3rem, 2.4750rem + 2.6250vw, 5.625rem);
	height: 100%;
}

.testimonials .box img {
	max-width: 190px;
	margin-bottom: clamp(3rem, 2.4750rem + 2.6250vw, 5.625rem);
	border-radius: 50%;
}

.testimonials .box p:last-child {
	margin-top: auto;
}

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

.contact {
	margin-bottom: clamp(5rem, 3.8100rem + 5.9500vw, 10.95rem);
}

.contact h2 {
	text-align: center;
	margin-bottom: clamp(3rem, 2.4000rem + 3.0000vw, 6rem);
}

.contact form {
	max-width: 750px;
	margin: 0 auto;
	padding-top: clamp(1.5rem, 1.2000rem + 1.5000vw, 3rem);
}

.contact .form-control:not(.is-invalid, .is-valid),
.contact .form-select {
	border-color: #766666;
}

.contact .msg-error {
	padding: 10px;
	background-color: #dc3545;
	color: #FFFFFF;
}

.contact .msg-success {
	padding: 10px;
	background-color: #198754;
	color: #FFFFFF;
}

.contact .form-item input,
.contact .form-item textarea,
.contact .form-item select {
	font-family: "Poppins", sans-serif;
	font-size: 20px;
	padding: 1.2rem 1.1rem;
	border-radius: 5px;
}

/****************************************************************** ARTICLE ***/

.article {
	padding-top: clamp(4rem, 3.2000rem + 4.0000vw, 8rem);
	padding-bottom: clamp(4rem, 3.2000rem + 4.0000vw, 8rem);
}

.article h2 {
	font-weight: 700;
}

.article .gallery {
	--bs-gutter-x: 30px;
	--bs-gutter-y: 30px;
	border-bottom: clamp(1rem, 0.2000rem + 4.0000vw, 5rem) solid #FFFFFF;
	border-top: clamp(1rem, 0.4000rem + 3.0000vw, 4rem) solid #FFFFFF;
}

.article .gallery img {
	border-radius: 5px;
}

.article-list-item {
	margin-bottom: clamp(4rem, 3.1000rem + 4.5000vw, 8.5rem);
}

.article-list-item img {
	border-radius: 5px;
	max-width: 100%;
	margin-bottom: clamp(1.8rem, 1.5200rem + 1.4000vw, 3.2rem);
}

@media (min-width: 768px) {

	.article-list-item img {
		max-width: 50%;
	}

}

/****************************************************************** LESSONS ***/

.lessons form {
	max-width: 750px;
	padding-top: clamp(1rem, 0.8000rem + 1.0000vw, 2rem);
	padding-bottom: clamp(3rem, 2.0000rem + 5.0000vw, 8rem);
}

.lessons .form-control:not(.is-invalid, .is-valid),
.lessons .form-select {
	border-color: #766666;
}

.lessons .msg-error {
	padding: 10px;
	background-color: #dc3545;
	color: #FFFFFF;
}

.lessons .msg-success {
	padding: 10px;
	background-color: #198754;
	color: #FFFFFF;
}

.lessons .form-item input,
.lessons .form-item textarea,
.lessons .form-item select {
	font-family: "Poppins", sans-serif;
	font-size: 20px;
	padding: 1.2rem 1.1rem;
	border-radius: 5px;
}

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

.footer {
	background-color: #766666;
}

.footer,
.footer a,
.footer h2 {
	color: #FFFFFF;
}

.footer .container {
	padding-top: clamp(2rem, 1.6000rem + 2.0000vw, 4rem);
	padding-bottom: clamp(3rem, 2.2800rem + 3.6000vw, 6.6rem);
}

.footer .separator {
	background-color: #FFFFFF;
}

.footer .separator img {
	width: 100%;
	vertical-align: bottom;
}

.footer .person a {
	text-decoration: none;
}

.footer .person a:hover {
	text-decoration: underline;
}

.footer .social a {
	text-decoration: none;
	margin-right: 15px;
}

.footer .social img {
	height: 50px;
}

@media (min-width: 1200px) {

	.footer .social a {
		margin-right: 0;
		margin-left: 15px;
	}
}

.footer .cert img {
	width: 215px;
}

/****************************************************************** SPLETKO ***/

.spletko {
	padding: 30px 0;
	text-align: center;
	background-color: #FFFFFF;
}

.spletko a {
	text-decoration: none;
}

.spletko a img {
	height: 20px;
}

@media (min-width: 1500px) {

	.spletko {
		padding: 40px 0;
	}
	
	.spletko a img {
		height: 24px;
	}

}
