@import url("https://fonts.googleapis.com/css2?family=Amatic+SC&family=Inter:wght@400;600;700&family=Josefin+Sans:wght@300;400&family=Montserrat:wght@100&family=Noto+Sans:wght@100&family=PT+Serif:ital@1&family=Roboto+Condensed&family=Roboto+Slab:wght@100;200&family=Satisfy&display=swap");

* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}
body {
  width: 100vw;
  height: 100vh;
  background-color: antiquewhite;
  overflow-x: hidden;
  font-family: "Josefin Sans", sans-serif;
}

/*!SLIDE MENU BUTTON*************************************/
.slide-menu-btn-wrapper {
  width: 30px;
  height: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  left: 20px;
  opacity: 0;
}
.slide-menu-btn {
  position: absolute;
  width: 25px;
  height: 2px;
  background-color: #3b8edb;
  margin-left: 5px;
}
.slide-menu-btn::before,
.slide-menu-btn::after {
  content: "";
  position: absolute;
  width: 25px;
  height: 2px;
  background-color: #3b8edb;
}
.slide-menu-btn::before {
  content: "";
  top: -7px;
}
.slide-menu-btn::after {
  content: "";
  top: 7px;
}
.slide-menu-btn-wrapper:hover {
  cursor: pointer;
}

/*!NFO CONTAINER************************************/
.info {
  position: absolute;
  top: 100px;
  left: -500px;
  width: 500px;
  height: 500px;
  background-color: #3b8edb;
  z-index: 100;
  border-radius: 10px;
  color: white;
  transition: 0.5s linear transform;
  padding: 5px;
}
.info .zatvori {
  position: absolute;
  right: 0;
  margin-right: 10px;
  margin-top: 10px;
  border-radius: 50%;
  border: none;
  color: white;
  background-color: transparent;
  font-size: 1.2rem;
}
.info .zatvori:hover {
  cursor: pointer;
}
.info h3 {
  margin-top: 50px;
}
.info h2 {
  margin-top: 20px;
  text-decoration: underline;
}
.info ul {
  margin-top: 20px;
  margin-bottom: 5px;
}
.info ul li {
  padding: 3px;
  font-size: 1.1rem;
}

/*!SLIDE MENU****************************************/
.slide-menu {
  position: absolute;
  top: 0px;
  left: -300px;
  width: 300px;
  background-color: white;
  color: #3b8edb;
  /* height: 100vh; */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  z-index: 2;
  transition: 0.5s linear transform;
}
.slide-menu .zatvori-meni {
  position: absolute;
  right: 20px;
  top: 50px;
  color: #3b8edb;
  font-size: 1.2rem;
}
.slide-menu .zatvori-meni:hover {
  cursor: pointer;
}
.slide-menu .top-menu {
  width: 100%;
  height: 75px;
  margin-top: 150px;
  align-items: center;
  justify-content: center;
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid #3b8edb;
}
.slide-menu .top-menu p {
  padding: 5px 0;
  font-size: 1.2rem;
}
.slide-menu .top-menu p:hover {
  cursor: pointer;
}
.slide-menu,
.top-menu p:nth-child(3) {
  margin-bottom: 20px;
}
.slide-menu h2 {
  margin-top: 50px;
}
.slide-menu ul {
  list-style: none;
  width: 100%;
  text-align: center;
  margin-top: 30px;
}
.slide-menu li {
  color: #3b8edb;
  padding: 6px 0px;
  font-size: 1.2rem;
}
.slide-menu li:hover {
  cursor: pointer;
  font-size: 1.4rem;
  text-decoration: underline;
}
/*?NAVBAR******************************************/
.nav-bar {
  width: 100%;
  height: 100px;
  display: flex;
  align-items: center;
  background-color: white;
  justify-content: space-between;
}
.nav-bar ul {
  list-style: none;
  margin-right: 50px;
}
.nav-bar ul li {
  display: inline;
  padding: 0 20px;
  font-size: 1.2rem;
  color: #3b8edb;
}
.nav-bar ul li:hover {
  background-color: #3b8edb;
  color: white;
  cursor: pointer;

  border-radius: 10px;
}
.nav-bar img {
  width: 250px;
  height: 60px;
  margin-left: 40px;
}

/*?BUTTONS KATALOG******************************************/
.button-wrapper {
  width: 100%;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.button-wrapper .btn {
  width: 150px;
  margin: 0 10px;
  padding: 10px;
  border: none;
  border-radius: 10px;
  background-color: white;
  color: #3b8edb;
  font-size: 1rem;
}
.button-wrapper .btn:hover {
  background-color: #3b8edb;
  color: white;
  cursor: pointer;
}

/*?CONTENT WRAPPER**********************************************/

.content-wrapper {
  width: 100%;
  display: flex;
  height: 100%;
  align-items: flex-start;
  justify-content: flex-start;
}
.content-wrapper .list-menu {
  width: 300px;
  border-right: 2px solid white;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 80px;
}
.content-wrapper .list-menu h2 {
  color: #3b8edb;
  margin-bottom: 40px;
}
.content-wrapper .list-menu ul {
  list-style: none;
  width: 100%;
  text-align: center;
}
.content-wrapper .list-menu li {
  color: #3b8edb;
  padding: 6px 0px;
  font-size: 1.2rem;
}
.content-wrapper .list-menu li:hover {
  text-decoration: underline;
  cursor: pointer;
  font-size: 1.3rem;
}
.content-wrapper .main-items-wrapper {
  width: 100%;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.content-wrapper .items-wrapper {
  width: 1500px;
  height: 100%;
  justify-content: center;
  align-items: center;
  display: flex;
  flex-wrap: wrap;
}
.items-wrapper h1 {
  text-align: center;
  width: 100%;
  margin-top: 30px;
  background-color: white;
  color: #3b8edb;
}
.items-wrapper .cards-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  height: 100%;
  gap: 25px;
}
.cards-wrapper .fisher-opruge-wrapper {
  width: 100%;
  display: flex;
  height: 50%;
  padding: 150px;
}
.fisher-opruge-wrapper .fisher,
.am-opruge {
  width: 50%;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.fisher-opruge-wrapper .fisher img {
  width: 300px;
  height: 200px;
  margin-top: 30px;
  border-radius: 10px;
}

.fisher p:nth-child(1) {
  margin-top: 20px;
}
.am-opruge .am-opruge-images-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
}
.am-opruge .am-opruge-images-wrapper img {
  width: 320px;
  height: 200px;
  border-radius: 10px;
}
.am-opruge p,
.fisher p {
  font-size: 1.3rem;
  color: #3b8edb;
}
.am-opruge p:nth-child(1) {
  margin-top: 30px;
}

.vinkli-vezice-wrapper {
  width: 100%;
  height: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 150px;
}
.vinkli-vezice-wrapper .vinkli,
.vezice {
  width: 50%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  color: #3b8edb;
  font-size: 1.3rem;
}

.vinkli img,
.vezice img {
  width: 300px;
  height: 200px;
  border-radius: 10px;
  margin-bottom: 40px;
}
.vinkli p:nth-child(2) {
  margin-bottom: 50px;
  margin-top: 5px;
  text-align: center;
}
.vezice p:nth-child(2) {
  margin-bottom: 50px;
  text-align: center;
  margin-top: 5px;
}
.main-items-wrapper .informacije {
  width: 100%;
  height: 250px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: 1.3rem;
  display: none;
}
.main-items-wrapper .informacije p {
  width: 1000px;
}
/*?FOOTER**************************************************/
.footer {
  width: 100%;
  height: 200px;
  background-color: #3b8edb;
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  text-align: center;
  padding: 15px;
  font-size: 1.3rem;
  color: white;
  align-items: center;
  justify-content: center;
}
.footer p {
  margin-top: 10px;
}

/*?UTILITY CLASSES*/
.show-info {
  transform: translateX(500px);
}

.hide-info {
  transform: translateX(-500px);
}
.show-slide-menu {
  transform: translateX(300px);
}
.hide-slide-menu {
  transform: translateX(-300px);
}
.remove-info {
  display: none;
}

/*?ZA MOBILNI STILIZACIJA SADRZAJA**********************************/
.small-content-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  display: none;
  margin-top: 30px;
  gap: 20px;
}
.small-content-wrapper h1 {
  background-color: white;
  color: #3b8edb;
  width: 100%;
  text-align: center;
  margin-bottom: 30px;
}
.small-fisher-opruge-wrapper,
.small-vinkli-vezice-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.small-vinkli-vezice-wrapper {
  margin-left: 30px;
}
.small-fisher-opruge-wrapper {
  margin-bottom: 20px;
}
.small-fisher,
.small-am-opruge,
.small-vezice,
.small-vinkli {
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.small-fisher img,
.small-am-opruge img,
.small-vinkli img,
.small-vezice img {
  width: 50%;
  height: 200px;
  border-radius: 10px;
}
.small-am-opruge-images-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.small-fisher .small-opis,
.small-am-opruge .small-opis,
.small-vinkli .small-opis,
.small-vezice .small-opis {
  width: 100%;
  display: flex;
  flex-direction: column;
  text-align: center;
  align-items: center;
  color: #3b8edb;
  font-size: 1.1rem;
}
/*?STILIZACIJA ZA KARTICE KOJE SE OCITAVAJU IZ GLAVNOG MENIJA*/
.card {
  width: 350px;
  height: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20px;
}
.card h3 {
  width: 100%;
  text-align: center;
  margin-bottom: 15px;
  font-size: 1.3rem;
}
.card img {
  width: 50%;
  height: 200px;
  border-radius: 10px;
}
/*?STILIZACIJA ZA KARTICE KOJE SE UCITAVAJU DINAMICKI IZ SLIDE MENIJA**********************************/
.loading-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 30px;
}
.loading-card .title {
  width: 100%;
  text-align: center;
  margin-bottom: 10px;
  color: #3b8edb;
  font-size: 1.3rem;
}
.loading-card img {
  width: 60%;
  border-radius: 10px;
}

@media only screen and (max-width: 850px) {
  .nav-bar ul {
    display: none;
  }
  .nav-bar img {
    margin-left: 100px;
  }
  .slide-menu-btn-wrapper {
    opacity: 1;
  }
  .content-wrapper .list-menu {
    display: none;
  }
  .footer {
    display: none;
  }
  .vinkli-vezice-wrapper {
    margin-left: 100px;
  }
}
@media only screen and (max-width: 600px) {
  .content-wrapper {
    display: none;
  }
  .small-content-wrapper {
    display: block;
  }
  .info {
    width: 100%;
  }
}

/*?STILIZACIJA ZA LAP TOP==============================================*/
@media only screen and (max-width: 1600px) {
  .content-wrapper .list-menu {
    width: 500px;
    margin-top: 30px;
  }

  .content-wrapper .main-items-wrapper {
    width: 85%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .items-wrapper h1 {
    width: 80%;
    margin: 15px auto;
  }
}
