/*
 Theme Name: safarikids
 Author: tadamart.pl
 Version: 1.0
 */

:root {
  --bs-primary: #6eb59c !important;
  --bs-primary-rgb: 110, 181, 156 !important;
  --bs-secondary: #707070 !important;
  --bs-secondary-rgb: 112, 112, 112 !important;

  --bs-blue: #5990b2 !important;
  --bs-red: #ba6b7c !important;
  --bs-orange: #d07d48 !important;
  --bs-yellow: #f9ad77 !important;
  --bs-green: #6eb59c !important;
}

body {
  color: #707070;
  font-family: poppins, sans-serif;
}

.admin-bar {
  margin-top: 32px;
  z-index: 9999999 !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "hobeaux", sans-serif;
  font-weight: 400 !important;
}
strong {
  font-weight: 600;
}
a {
  transition: 0s !important;
  font-size: 14px;
}
p,
li,
td,
th {
  font-size: 14px;
  line-height: 1.8 !important;
}
.ls1 {
  letter-spacing: 1px !important;
}
.lh1 {
  line-height: 1 !important;
}
.grecaptcha-badge {
  display: none !important;
}
.cky-btn-revisit-wrapper {
  display: none !important;
}

.border-end,
.border-start,
.border-top,
.border-bottom,
.border {
  border-color: rgba(0, 0, 0, 0.05) !important;
}

.bg-black .border-end,
.bg-black .border-start,
.bg-black .border-top,
.bg-black .border-bottom,
.bg-black .border,
.bg-black.border-top {
  border-color: rgba(255, 255, 255, 0.15) !important;
}
.bg-red {
  background-color: var(--bs-red) !important;
}
.bg-orange {
  background-color: var(--bs-orange) !important;
}
.custom-page a {
  color: var(--bs-secondary);
}
.fs-6 {
  font-size: 12px !important;
}
.fs-7 {
  font-size: 10px;
}
.text-red {
  color: var(--bs-red) !important;
}
.text-blue {
  color: var(--bs-blue) !important;
}
.text-orange {
  color: var(--bs-orange) !important;
}
.text-yellow {
  color: var(--bs-yellow) !important;
}
.text-green {
  color: var(--bs-green) !important;
}
.logo {
  max-width: 180px;
}

.navbar .nav-link,
.navbar-nav .nav-item a {
  font-family: "hobeaux", sans-serif;
  font-size: 18px;
}
.navbar .nav-item a:hover {
  text-decoration: underline !important;
}
/* Dropdown chevron */
.dropdown-toggle::after {
  font-family: "bootstrap-icons" !important;
  content: "\f282" !important;
  border: none !important;
  vertical-align: middle;
  transition: transform 0.2s ease !important;
  display: inline-block;
}

.dropdown-toggle[aria-expanded="true"]::after {
  transform: rotate(180deg) !important;
}
header {
  box-shadow: 0px 0px 15px #0000000d;
  border-bottom-left-radius: 20px;
  position: relative;
}
.btn {
  font-family: "hobeaux", sans-serif;
  font-size: 18px;
  padding: 10px 25px;
  border-radius: 100px;
  font-weight: 400 !important;
}
.btn-primary {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  color: white !important;
}
.btn-primary:hover {
  background-color: var(--bs-blue) !important;
  border-color: var(--bs-blue) !important;
  color: white !important;
}
.btn-outline-orange {
  background-color: transparent !important;
  border-color: var(--bs-orange) !important;
  color: var(--bs-orange) !important;
}
.btn-outline-orange:hover {
  background-color: var(--bs-orange) !important;
  border-color: var(--bs-orange) !important;
  color: white !important;
}
.btn-outline-primary {
  background-color: transparent !important;
  border-color: var(--bs-primary) !important;
  color: var(--bs-primary) !important;
}
.btn-outline-primary:hover {
  background-color: var(--bs-blue) !important;
  border-color: var(--bs-blue) !important;
  color: white !important;
}
.btn-light {
  background-color: white !important;
  border-color: white !important;
  color: var(--bs-primary) !important;
}
.btn-light:hover {
  background-color: var(--bs-yellow) !important;
  border-color: var(--bs-yellow) !important;
  color: white !important;
}
.btn-outline-light {
  background-color: transparent !important;
  border-color: white !important;
  color: white !important;
}
.btn-outline-light:hover {
  background-color: var(--bs-yellow) !important;
  border-color: var(--bs-yellow) !important;
  color: white !important;
}
.navbar-nav .dropdown-menu {
  border-radius: 15px;
  box-shadow: 0px 0px 15px #0000000d;
  border: 0px;
}
.dropdown-item {
  color: var(--bs-secondary);
  font-family: "hobeaux", sans-serif;
  font-size: 16px;
}
.dropdown-item:focus,
.dropdown-item:hover {
  background-color: transparent;
  color: var(--bs-red);
}
.half-fluid .left-half,
.half-fluid .right-half {
  left: 50%;
  margin-left: -50vw;
  max-width: 100vw;
  position: relative;
  right: 50%;
  width: 100vw;
  padding: 0px;
}
.half-fluid .image {
  background-size: cover;
  background-position: center;
  min-height: 300px;
  height: 100%;
}
.hero {
  margin-top: -25px;
}
.min1 {
  min-height: 600px;
}
.max1 {
  max-width: 450px;
  margin: 0 auto;
}
.hero-icon {
  position: absolute;
}
.hi1 {
  top: 0;
  right: 0;
}
.hi2 {
  bottom: 0;
  left: 50%;
}
.hi3 {
  top: 0;
  left: 50%;
}
.hi4 {
  bottom: 0;
  right: 0;
}
.card-img {
  height: 200px;
  object-fit: cover;
  object-position: center;
}
.card-blue {
  background: linear-gradient(to right, #c1dff6, #daeefd);
}
.card-blue h3,
.card-blue p {
  color: var(--bs-blue);
}
.card-blue .btn {
  color: var(--bs-blue) !important;
}
.card-blue .btn:hover {
  color: white !important;
  background-color: var(--bs-blue) !important;
  border-color: var(--bs-blue) !important;
}
.card-red {
  background: linear-gradient(to right, #fbd5db, #fde2e6);
}
.card-red h3,
.card-red p {
  color: var(--bs-red);
}
.card-red .btn {
  color: var(--bs-red) !important;
}
.card-red .btn:hover {
  color: white !important;
  background-color: var(--bs-red) !important;
  border-color: var(--bs-red) !important;
}
.card-orange {
  background: linear-gradient(to right, #ffe4ce, #ffecdd);
}
.card-orange h3,
.card-orange p {
  color: var(--bs-orange);
}
.card-orange .btn {
  color: var(--bs-orange) !important;
}
.card-orange .btn:hover {
  color: white !important;
  background-color: var(--bs-orange) !important;
  border-color: var(--bs-orange) !important;
}
.sec2 {
  margin-top: -70px;
}
.card-icon {
  position: absolute;
  top: 0;
  right: 0;
  height: 90px;
  width: 90px;
  margin: 10px 20px;
}
.cb2 {
  background: linear-gradient(to right, #eff7fd, #f6fbff);
}
.cr2 {
  background: linear-gradient(to right, #fef3f5, #fef8f9);
}
.co2 {
  background: linear-gradient(to right, #fff8f2, #fffbf7);
}
.ci2 {
  max-height: 65px;
}
.mymaps-info-window .btn {
  display: none;
}
.mymaps-point-card {
}
.mymaps-point-card .btn {
  display: block;
  height: fit-content;
  color: var(--bs-blue) !important;
}
.mymaps-point-card .btn:hover {
  color: white !important;
  background-color: var(--bs-blue) !important;
  border-color: var(--bs-blue) !important;
}
.mymaps-point-card p {
  margin-bottom: 0px;
}
.badge-map {
  background-color: white;
  color: var(--bs-blue) !important;
  border-radius: 100px;
  padding: 5px 10px;
  font-size: 12px;
  font-family: "hobeaux", sans-serif;
}
.mymaps-info-window .badge-map {
  background: linear-gradient(to right, #eff7fd, #f6fbff);
}
.gm-style .gm-style-iw-c {
  border-radius: 25px !important;
  box-shadow: none !important;
}
.mymaps-info-window a {
  text-decoration: none !important;

  font-weight: 500 !important;
  outline: none !important;
  font-size: 16px !important;
  color: var(--bs-blue) !important;
}
.mymaps-info-window {
  max-width: 300px;
}

.mymaps-info-window h4 {
  margin: 0 0 10px 0;
  color: #333;
}

.mymaps-info-window p {
  margin: 0;
  color: #666;
  line-height: 1.5;
}

.mymaps-custom-marker {
  position: absolute;
  transform: translate(-50%, -100%);
  cursor: pointer;
}

.mymaps-marker-container {
  position: relative;
  width: 52px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.mymaps-marker-box {
  width: 30px;
  height: 30px;
  background: white;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 1px solid rgba(0, 0, 0, 0.08);
}

.mymaps-marker-box img {
  width: 26px;
  height: 26px;
  object-fit: cover;
  border-radius: 8px;
}

.mymaps-marker-box-default {
  width: 18px;
  height: 18px;
  background: #0073aa;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mymaps-marker-box-default::after {
  content: "";
  width: 10px;
  height: 10px;
  background: white;
  border-radius: 50%;
}
.mymaps-frontend-map {
  width: 100%;
  height: 660px;
  border-radius: 25px;
}

.mymaps-marker-arrow {
  width: 0;
  height: 0;
  border-left: 8px solid transparent;
  border-right: 8px solid transparent;
  border-top: 10px solid white;
  margin-top: -1px;
  filter: drop-shadow(0 2px 2px rgba(0, 0, 0, 0.15));
}
.gm-style-iw button {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
}
.mymaps-points-list {
  height: 670px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding-right: 25px;

  /* Ukryj domyślny scrollbar - Firefox */
  scrollbar-width: none;

  /* Ukryj domyślny scrollbar - Webkit browsers (Chrome, Safari, Edge) */
  &::-webkit-scrollbar {
    display: none;
  }
}

.mymaps-info-window {
  margin-top: 0px;
  padding: 10px;
}
.space-img img {
  height: 400px;
  object-fit: cover;
  object-position: center;
}
.eu {
  height: 40px;
  mix-blend-mode: multiply;
}
.sec5 .btn-light {
  color: var(--bs-red) !important;
}
.sec5 .btn-light:hover {
  color: white !important;
}
/* formularz */
.form-check .form-check-input {
  margin-left: -2rem !important;
}
.form-check-input {
  width: 18px !important;
  height: 18px !important;
  cursor: pointer !important;
  border-color: rgba(255, 255, 255, 1) !important;
  background-color: transparent !important;
  color: white !important;
  border-radius: 6px !important;
  outline: none !important;
  box-shadow: none !important;
  &:checked {
    border-color: white !important;
    color: white !important;
    outline: none !important;
    box-shadow: none !important;
  }
}
.accept label {
  cursor: pointer !important;
  font-size: 11px !important;
}
.wpcf7-spinner {
  position: absolute !important;
}
.wpcf7-submit {
  transition: 0s !important;
}
.wpcf7-not-valid-tip {
  font-size: 12px !important;
  color: #b70000 !important;
  margin-top: 5px !important;
  margin-bottom: 0px !important;
}
.wpcf7 p {
  margin-bottom: 0px !important;
}
.form-label {
  width: 100% !important;
}
.form-select {
  cursor: pointer !important;
}
.form-select,
.form-control {
  border-radius: 25px !important;
  padding: 15px 25px !important;
  font-size: 14px !important;
  width: 100% !important;
  border: 0px;
  &:focus {
    outline: none !important;
    box-shadow: none !important;
    border: 0px;
  }
}
::placeholder {
  color: #707070 !important;
}
textarea {
  height: 100px !important;
}
/* formularz */

/* Gallery Tabs Styling */
#galleryTabs .nav-link {
  font-family: "hobeaux", sans-serif;
  font-size: 20px;

  color: var(--bs-secondary);
}

#galleryTabs .nav-link:hover {
  background-color: transparent;
  color: var(--bs-primary);
}

#galleryTabs .nav-link.active {
  color: var(--bs-primary);
  background-color: transparent;
  text-decoration: underline;
}

.tab-content a {
  display: block;
  overflow: hidden;
  border-radius: 15px;
}

.tab-content a:hover {
}

.tab-content img {
  transition: transform 0.3s ease;
}

.tab-content a:hover img {
  transform: scale(1.1);
}
.gallery img {
  height: 250px;
  object-fit: cover;
  object-position: center;
}
.bg-red .btn-light {
  color: var(--bs-red) !important;
}
.bg-red .btn-light:hover {
  color: white !important;
}
.bg-orange .btn-light {
  color: var(--bs-orange) !important;
}
#mainNav {
  transition: all 0.3s ease-in-out;
  position: relative;
  z-index: 1050;
}

#mainNav.is-sticky {
  position: fixed !important;
  top: 0 !important;
  left: 0;
  right: 0;
  width: 100%;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
  z-index: 1050 !important;
}

.nav-spacer {
  display: none;
}

.nav-spacer.active {
  display: block;
}
.sec3-icon {
  margin-top: -70px;
}
footer .form-check-input {
  border-color: var(--bs-secondary) !important;
  color: var(--bs-secondary) !important;
  &:checked {
    border-color: var(--bs-secondary) !important;
    filter: invert(1);
  }
}
footer .form-control {
  border-radius: 0 !important;
  background-color: transparent !important;
  border-bottom: 1px solid var(--bs-secondary) !important;
  padding: 5px 0px !important;
  &:focus {
    outline: none !important;
    box-shadow: none !important;
    border-color: var(--bs-secondary) !important;
  }
}
footer .form-control::placeholder {
  color: var(--bs-secondary) !important;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  font-size: 12px !important;
  border-radius: 15px !important;
}
.card-text p:last-child {
  margin-bottom: 0px !important;
}

/* Animacje dla ikon */
@keyframes float {
  0%,
  100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-25px);
  }
}

@keyframes floatRotate {
  0%,
  100% {
    transform: translateY(0px) rotate(0deg);
  }
  50% {
    transform: translateY(-20px) rotate(8deg);
  }
}

@keyframes pulse {
  0%,
  100% {
    transform: scale(1);
    opacity: 0.7;
  }
  50% {
    transform: scale(1.15);
    opacity: 1;
  }
}

@keyframes bounce {
  0%,
  100% {
    transform: translateY(0px) scale(1);
  }
  25% {
    transform: translateY(-15px) scale(1.05);
  }
  50% {
    transform: translateY(-25px) scale(1.1);
  }
  75% {
    transform: translateY(-15px) scale(1.05);
  }
}

@keyframes rotate {
  0%,
  100% {
    transform: rotate(-5deg);
  }
  50% {
    transform: rotate(5deg);
  }
}

/* Animacje dla hero-icon */
.hero-icon.hi1 {
  animation: float 5s ease-in-out infinite;
}

.hero-icon.hi2 {
  animation: floatRotate 6s ease-in-out infinite;
  animation-delay: 1s;
}

.hero-icon.hi3 {
  animation: bounce 5.5s ease-in-out infinite;
  animation-delay: 1.5s;
}

.hero-icon.hi4 {
  animation: floatRotate 7s ease-in-out infinite;
  animation-delay: 0.5s;
}

/* Animacje dla card-icon */
.card-icon {
  animation: rotate 3s ease-in-out infinite;
}

/* Animacje dla sec3-icon */
.sec3-icon {
  animation: rotate 4s ease-in-out infinite;
}

@media (min-width: 992px) {
  .half-fluid .left-half {
    padding-left: 0 !important;
    position: absolute;
    left: 0;
    right: 50%;
    margin-left: auto;
    width: auto;
  }
  .half-fluid .right-half {
    padding-right: 0 !important;
    position: absolute;
    right: 0;
    left: 50%;
    margin-left: auto;
    width: auto;
  }
}

@media (min-width: 1400px) {
}

/* XX-Large devices (larger desktops) */
@media (max-width: 1399.98px) {
  .navbar .nav-link {
    font-size: 16px;
  }
}

/* X-Large devices (large desktops) */
@media (max-width: 1199.98px) {
}

/* Large devices (desktops) */
@media (max-width: 991.98px) {
  .hero-icon {
    max-width: 150px;
  }
  .hi1 {
    top: 40%;
    right: 0;
  }
  .hi2 {
    bottom: 0;
    left: 0;
  }
  .hi3 {
    top: 40%;
    left: 0;
  }
  .hi4 {
    bottom: 0;
    right: 0;
  }
  .sec3 img {
    max-width: 100px;
  }
}

/* Medium devices (tablets) */
@media (max-width: 767.98px) {
  #galleryTabs .nav-link {
    font-size: 16px;
    padding: 10px 25px;
    margin: 0 5px;
  }
  header .btn {
    font-size: 14px;
    padding: 8px 20px;
  }
  header .logo {
    max-width: 100px;
  }
  .eu {
    height: 30px;
  }
}

/* Small devices (landscape phones) */
@media (max-width: 575.98px) {
  #galleryTabs .nav-link {
    font-size: 14px;
    padding: 8px 20px;
    margin: 5px;
  }
}
