*
{
	margin: 0;
	padding: 0;
	font-family: 'calibiri', sans-serif; 
}

header
{
	display: flex;
	flex-direction: column;
	position: sticky;
	top: -40px;
	background-color: white;
	z-index: 2;
}

nav.top-banner
{
	display: flex;
	justify-content: center;
	color: white;
	padding: 10px;
	padding-left: 10px;
	background-color: #313f9a;
}

nav
{
	padding-top: 5px;
	display: flex;
	gap: 4%;
	font-family: 'calibiri', sans-serif; 
	margin-bottom: 10px;
	z-index: 3;
}

nav > img
{
	height: 4rem;
	padding-left: 3%;
}

input
{
	display: none;
}

label
{
	position:relative;
}

label.menu
{
	display: none;
}

.outside
{
	width: 100%;
	display: flex;
	justify-content: space-evenly;
	align-items: center;
}

.outside > a , a
{
	color: black;
	text-decoration: none;
}

.outside  label , .outside > a
{ 
	font-size: 1.3rem;
	color: #313f9a;
	padding: 5px;
	padding-left: 20px;
	padding-right: 20px;
	border-radius: 1rem;
}

.outside > a , .outside label
{
	transition: 0.5s background-color, 0.5s color;
}

.outside > a.active , label.active
{
	color: white;
	background-color: #313f9a;
	padding: 5px;
	padding-left: 20px;
	padding-right: 20px;
	border-radius: 1rem;
}

.outside > a:hover , .outside label:hover , .inside li a:hover
{
	color: white;
	background-color: #313f9a;
}

.collaplible-menu
{
	display: flex;
	flex-direction: column;
}

.inside {
	display: none;
	font-family: 'calibiri', sans-serif;
	margin-left: 10px;
	padding: 10px;
	margin-bottom: 0;
	padding-bottom: 10px;
}

.inside ul , .insdie div ul
{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin:0;
	gap: 10px;
}

.inside li , .inside div li
{
	list-style: none;
	text-align: center;
	margin: 0;
	padding: 0;
}

.inside li a , .inside div li a
{
	font-size: 1rem;
	color: #313f9a;
	padding: 5px;
	padding-left: 20px;
	padding-right: 20px;
	border-radius: 1rem;
}

input:hover ~ .inside, .inside:hover, input:checked ~ .inside
{
	display: flex;
	flex-direction: column;
	position: absolute;
	top: 100px;
	z-index: 6;
	overflow: visible;
	background-color: white;
	box-shadow: 0px 7px 12px -10px #1a2354ab;
}

nav.bread-crumbs
{
	overflow: auto;
	box-shadow: 0px 5px 9px -1px #1a2354ab;
}

nav.bread-crumbs , nav.bread-crumbs > a
{
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0;
	color: white;
	padding: 7px;
	padding-left: 0.5rem;
	margin-bottom: 0;
	z-index:1;
	background-color: #313f9a;
	text-wrap: nowrap;
}

nav.bread-crumbs > a:hover
{
	text-decoration: underline;
}

li.submenu ~ ul > li
{
	display: block;
	padding-left: 10px;
}

li.submenu ~ ul
{
	margin-top: 1px;
}

li.submenu > a
{
	display: block;
	text-align:start;
}

li.hidden ~ ul > li
{
	margin: 0;
	padding: 0;
	display: none;
	height: 0px;
}

main
{
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

section.image-carocell > div > img
{
	width: 100%;
	height: 30rem;
	object-fit: cover;
	/*box-shadow: 0px -4px 26px 14px rgb(86 83 83 / 68%);*/
}

.image-carocell
{
	margin-bottom: 5rem;
	width: 100%;
}

button 
{
	border: none;
	background-color: transparent;
	font-size: 3rem;
	color: #000000a1;
	padding: 1px;
}

.image
{
	display: none;
}

.prev, .next {
  cursor: pointer;
  position: absolute;
  top: 22rem;
  width: auto;
  margin-top: -22px;
  padding: 16px;
  color: white;
  font-weight: bold;
  font-size: 18px;
  transition: 0.6s ease;
  border-radius: 0 5px 5px 0;
  user-select: none;
}

.next {
  right: 0;
  border-radius: 5px 0 0 5px;
}

.prev:hover, .next:hover {
  background-color: rgb(0 0 0 / 28%);
}

section.content
{
	padding: 20px;
}

section.content > div.first
{
	display: flex;
	margin-bottom: 2rem;
	align-items: center;
	gap: 4rem;
	justify-content: space-around;
}

section > div.grid
{
	margin-top: 2.5rem;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

div.grid img
{
	height: 400px;
	width: 400px;
	border: 3px solid transparent;
	border-radius: 10px;
	object-fit:cover;
	transition: filter 0.2s;
}

div.grid img:hover
{
	filter: brightness(0.5);
	cursor: pointer;
}

div.contact
{
	align-items:center;
}

section.content > div.second
{
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
	gap: 4rem;
	justify-content: space-around;
}

section.content-container
{
	display: flex; 
	gap: 20%; 
	flex-wrap: wrap; 
	justify-content: center;
	width: 100%;
}

.first
{
	margin-top: 2rem;
}

.first:last-child, .second
{
	margin-top: 4rem;
}

div.left 
{
	padding: 1rem;
}

div.left > h4
{
	margin-top: 0.5rem;
	text-align: center;
}

div.right
{
	padding: 1rem;
}

div.right h3
{
	margin-top: 2rem;
	margin-bottom: 2rem;
	text-align: center;
}

div.right > p
{
	width: 500px;
	text-align: center;
}

section.content-container > div.left > h1
{
	margin-bottom: 2rem;
}

div.right > div 
{
	border-bottom: 2px solid #313f9a;
	padding: 1rem 1rem 1rem 0;
	margin-top: 2rem;
	margin-bottom: 2rem;
}

div.right > div > h3
{
	margin-bottom: 1rem;
	font-size: 1.5rem;
	padding: 10px;
}

div.menu > h3
{
	text-align: center;
	color: white;
	background-color: #313f9a;
	border-bottom: 1px white solid;
}

div.right > div.menu
{
	border: none;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 1.5rem;
	padding: 20px;
	margin-right: 10%;
	background-color: #313f9a;
}

div.second > div.menu
{
	width: 20%;
	height: 23rem;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	gap: 1.5rem;
	padding: 20px;
	background-color: #313f9a;
	overflow: auto;
}

section.content > div.menu-container
{
	flex-direction:row; 
	align-items: flex-start; 
	flex-wrap: wrap; 
	gap: 0; 
	row-gap: 1rem;
}

div.menu > a:hover
{
	color: #313f9a;
	background-color: white;
}

div.menu > a
{
	font-size: 1.5rem;
	color: white;
	background-color: #313f9a;
	padding: 10px;
	border-radius: 1rem;
	text-align: center;
}

section.content > div div p
{
	margin-bottom: 1rem;
}

div.right > div.contact
{
	padding: 1rem 0 1rem 0;
}

div.info 
{
	margin-top: 3rem;
	margin-bottom: 5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.7rem;
	flex-wrap: wrap;
}

div.info > div
{
	height: 200px;
	width: 200px;
	background-color: #313f9a;
	text-align: center;
	color: white;
	padding: 1rem;
}

div.info > div > h2
{
	margin-top: 1rem;
	margin-bottom: 1rem;
	font-size: 1.3rem;
}

.invisible
{
	display: none;
}

section.gallery-fullscreen.invisible
{
	display: none;
}

section.gallery-fullscreen
{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: fixed;
	z-index: 5;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.747);
	backdrop-filter: blur(4px);
}

section.gallery-fullscreen img
{
	max-height: 100%;
	max-width: 50%;
	object-fit: contain;
	display: block;
	margin: auto;
}

button.close
{
	position: absolute;
	padding: 0.7rem;
	padding-left: 0.6rem;
	padding-right: 0.6rem;
	top: 10px;
	right: 25px;
	background-color: transparent;
	border: none;
	color: white;
	font-size: 2rem;
	cursor: pointer;
	transition: 0.3s background-color;
	appearance: none;
}

button.close:hover
{
	background-color:rgba(0, 0, 0, 0.199)
}

section.gallery-fullscreen button.prev, section.gallery-fullscreen  button.next
{
	top: 50%;
	border-radius: 0;
	font-size: 30px;
}
section.gallery-fullscreen button.prev
{
	left: 10%;
}

section.gallery-fullscreen button.next
{
	right: 10%;
}

div div h1
{
	margin-bottom: 10px;
}

footer
{
	margin-top: 2rem;
	padding: 2rem;
	background-color: #313f9a;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: white;
}

footer > nav
{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 1.3rem;
	width: 25%;
	border-right: 1px white solid;
	z-index: 1;
}

footer > nav:first-child
{
	gap: 0;
	margin-bottom: 0;
	padding-top: 15px;
}

footer a
{
	color: white;
	text-decoration: none;
}

footer > nav > nav > a
{
	transition: 0.5s text-decoration;
}

footer > nav > nav > a:hover
{
	text-decoration: underline;
}

footer > nav > a > img
{
	height: 75px ;
}

footer h3
{
	margin-bottom: 1rem;
	padding: 0.3rem;
	padding-bottom: 0.5rem;
	font-size: 1.5rem;
	border-bottom: solid white;
}

h4
{
	text-align: center;
	font-size: 1.2rem;
	margin-bottom: .7rem;
}

h4 + p
{
	margin-bottom: 1rem;
}

h1 + p
{
	margin-bottom: 1rem;
}

img.fix
{
	width: 50vw;
}

img.tall
{
	width: 35vw;
}

footer > nav:nth-child(2)
{
	flex-direction: row;
	justify-content: center;
	align-items: flex-start;
	gap: 12%;
	width: 75%;
	border-right: none;
}

footer > nav:nth-child(2) > nav
{
	display:flex;
	flex-direction:column;
	align-items: flex-start;
	gap: 0.5rem;
}

footer > nav > nav.socials > a > img
{
	background-color: white;
	height: 35px;
	width: 35px;
	border: 5px transparent solid;
	border-radius: 5px;
}

footer.bottom-banner
{
	margin: 0;
	padding: 10px 0;
	width: 100%;
	font-size: 0.7rem;
	text-align: center;
	display: flex;
	justify-content: center;
}
