.gradient-line {
  border: 0;
  height: 2px;
  background: linear-gradient(to right, transparent, #c3a567, transparent);
}

.ciemny-obraz {
  /* * Używamy funkcji brightness() z modułu filter.
   * Wartość 1.0 to pełna jasność (bez zmian).
   * Wartość 0.5 to 50% oryginalnej jasności (pociemnienie o połowę).
   * Wartość 0.0 to całkowita czerń.
   */
  filter: brightness(0.7); /* Obraz będzie o 30% ciemniejszy */
}

.icon3 {
  width: 150px;
}

.round_image {
  /* Ustalenie kształtu kwadratu */
  width: 300px;
  height: 300px;

  /* Dopasowanie obrazka do kwadratu (bez rozciągania) */
  object-fit: cover;

  /* KLUCZOWY KROK: Utworzenie kółka */
  border-radius: 50%;
}

.pozioma-kreska-border {
  /* Nadaje lewą krawędź jako kreskę */
  border-bottom: 1px solid #c3a567; /* Grubość | Styl | Kolor */
  /* Opcjonalne: Ustalenie wysokości i marginesu */
  width: 200px;
}

.pionowa-kreska-border {
  /* Nadaje lewą krawędź jako kreskę */
  border-left: 1px solid #c3a567; /* Grubość | Styl | Kolor */
  /* Opcjonalne: Ustalenie wysokości i marginesu */
  height: 100px;
  margin-left: 10px;
  padding-left: 10px; /* Odstęp między kreską a treścią */
}

.dark_blue_bg {
  background-color: #050a0f !important;
}

.gold_text {
  color: #c3a567 !important;
}

body {
  font-family: "Exo", sans-serif;
}

.image-overlay-container {
  width: 100%; /* Ustaw szerokość (dostosuj) */
  height: 100%; /* Ustaw wysokość (dostosuj) */

  /* 1. Ustawienie obrazu tła */
  background-image: url("/img/skyparks.webp");
  background-size: cover; /* Sprawia, że obraz pokrywa cały kontener */
  background-position: center; /* Wyśrodkowanie obrazu */

  /* 2. KLUCZOWY KROK: Nakładanie gradientu i obrazu */
  /* Przypisujemy dwie wartości do background-image, oddzielone przecinkiem: */
  /* a) Gradient, który ma być NA WIERZCHU */
  /* b) Obraz tła, który ma być POD SPODEM */
  background-image: linear-gradient(to top, #050a0f, rgba(255, 255, 255, 0.1)),
    url("/img/skyparks.webp");
}

.main-text {
  font-family: "Michroma", sans-serif;
}

.text1 {
  font-size: 1.3em;
}

.dark_blue {
  color: #09131d !important;
}

/* Zapewnia wygląd okręgu z obrazka */
.icon-circle {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background-color: rgba(0, 0, 0, 0); /* Przybliżony kolor brązowo-złoty */
}

/* Dostosowanie obrazu wewnątrz okręgu */
.icon-circle img {
  width: 40px; /* Rozmiar ikony wewnątrz okręgu */
  height: 40px;
}

/* Poprawka marginesu dla nagłówka */
.feature-text h4 {
  margin-top: 0;
}

.navbar {
  /* Wyprowadzamy navbar ze standardowego obiegu, 
       dzięki czemu sekcja hero wskoczy na górę */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;

  /* Ustawiamy bardzo wysoki z-index, aby był zawsze widoczny */
  z-index: 100;

  /* Ustawienie przezroczystości (tak jak na obrazku) */
  background-color: transparent;
  color: white; /* Ustawienie koloru tekstu na biały */
  padding: 20px 50px; /* Dodajemy padding do wyglądu */
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  margin: 0;
  padding: 0;

  font-family: "Michroma", sans-serif;
}

body {
  margin: 0;
  padding: 0;
}

h1 {
  font-size: 3rem;
  font-weight: 600;
}

h2 {
  font-size: 2.5rem;
}

p {
}

@media (max-width: 991px) {
  /* Wyłącz bootstrapowe display:none/block dla collapse */
  #mobileNavbar .nav-link {
    font-size: 2rem; /* lub większa wartość np. 1.5rem */
    margin-top: 0.6rem;
    margin-bottom: 0.6rem;
  }

  .lang-button {
    width: 70px; /* większa szerokość */
    height: 70px; /* większa wysokość */
  }

  .lang-button img {
    width: 40px; /* większy rozmiar flagi w przycisku */
  }
  #mobileNavbar {
    display: block !important;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    background-color: #09131d;
    z-index: 1050;
    padding: 2rem 1.5rem;
    overflow-y: auto;

    /* Start poza ekranem po lewej */
    transform: translateX(-100%);
    transition: transform 0.3s ease-in-out;
  }

  /* Gdy pokazujemy menu - przesuwamy na ekran */
  #mobileNavbar.show {
    transform: translateX(0);
  }

  /* Ukrywamy poza ekranem zamiast display:none (bootstrap często zmienia display) */
  #mobileNavbar.collapsing {
    transition: none !important; /* wyłącz animację bootstrap podczas collapsing */
  }

  .navbar-toggler {
    z-index: 1100;
  }
}

.navbar-toggler:hover {
  background-color: #09131d;
  border: 1px solid white;
}

.navbar-brand:hover {
  filter: brightness(0.8);
}

li a {
  color: white !important;
  text-decoration: none;
  position: relative; /* Umożliwia pozycjonowanie absolutne podkreślnika */
  display: inline-block;
  padding-bottom: 3px; /* Przestrzeń pod tekstem dla podkreślenia */
  /* transition: color 0.3s ease; -- Opcjonalnie: dla płynnej zmiany koloru tekstu */
}

/* 2. Tworzenie samego podkreślnika (początkowo niewidocznego) */
li a::after {
  content: "";
  position: absolute;
  width: 0; /* Szerokość zerowa (niewidoczny) */
  height: 2px; /* Grubość podkreślenia */
  bottom: 0; /* Umieszczenie na dole linku */
  left: 0; /* Zaczynamy rysowanie od lewej */
  background-color: #b99b5d; /* Kolor podkreślenia (złoty) */
  transition: width 0.3s ease-out; /* Animacja rysowania */
}

/* 3. Akcja po najechaniu (hover) */
li a:hover {
  text-decoration: none;
  color: #b99b5d !important; /* Zmiana koloru tekstu na złoty */
}

li a:hover::after {
  width: 100%; /* Rysowanie podkreślnika na pełną szerokość */
}

.fb_ig {
  transition: filter 0.2s ease;
}

.fb_ig:hover {
  filter: brightness(0.7);
}

.carousel-inner img {
  width: 100%;
  object-fit: cover;
  object-position: center; /* to właśnie ustawia wyśrodkowanie */
  object-fit: cover;
}

@media (min-width: 768px) {
  .carousel-inner img {
    height: 800px; /* albo inna stała wysokość karuzeli */
  }
}

.wall_bg {
  border-bottom-left-radius: 20px;
  border-bottom-right-radius: 20px;

  background-size: cover;
  background-position: center;
  width: 100vw;
  height: 40vh;
  overflow: hidden;
}

@media (max-width: 768px) {
  .wall_bg {
    height: auto;
    padding: 90px 20px;
  }
}

.Valencia_bg {
  /* Ustawienie kontekstu dla pozycjonowania wideo */
  position: relative;
  height: 100vh;
  width: 100vw;
  overflow: hidden; /* Zapobiega paskom przewijania, jeśli film jest za duży */
  /* background-image usunięte */
}

.Valencia_bg video {
  /* Pozycjonowanie filmu w tle */
  position: absolute;
  top: 50%; /* Pomaga w centrowaniu */
  left: 50%; /* Pomaga w centrowaniu */
  transform: translate(-50%, -50%); /* Ostateczne centrowanie */

  /* Zapewnienie, że film zawsze zakryje cały kontener */
  min-width: 100%;
  min-height: 100%;

  /* Dopasowanie do kontenera (jak background-size: cover) */
  object-fit: cover;

  /* Upewnienie się, że film jest za treścią */
  z-index: 1;
}

@media (max-width: 768px) {
  .Valencia_bg_wrapper2 {
    min-height: 100vh;
    width: 100vw;
    overflow: hidden; /* Zapobiega paskom przewijania, jeśli wideo jest za duże */
    position: relative; /* Absolutnie wymagane do pozycjonowania wideo i treści */
  }
}

@media (min-width: 768px) {
  .Valencia_bg_wrapper2 {
    position: relative; /* Absolutnie wymagane do pozycjonowania wideo i treści */
    height: 100vh; /* Gwarantuje, że kontener zajmuje całą wysokość okna */
    width: 100vw;
    overflow: hidden; /* Zapobiega paskom przewijania, jeśli wideo jest za duże */
  }
}

.Valencia_bg_wrapper {
    position: relative; /* Absolutnie wymagane do pozycjonowania wideo i treści */
    height: 100vh; /* Gwarantuje, że kontener zajmuje całą wysokość okna */
    width: 100vw;
    overflow: hidden; /* Zapobiega paskom przewijania, jeśli wideo jest za duże */
  }

/* 2. Warstwa WIDEO: Podstawa (z-index: 1) */
.background-video {
  /* Wychodzimy z normalnego przepływu */
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%); /* Technika do idealnego centrowania */

  /* Gwarantuje wypełnienie całego kontenera bez deformacji */
  min-width: 100%;
  min-height: 100%;
  object-fit: cover;

  z-index: 1; /* Najniższa warstwa */
}

/* 3. Warstwa OVERLAY: Przyciemnienie (z-index: 5) */
.video-overlay2 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  background: linear-gradient(to top, #050a0f, rgba(255, 255, 255, 0.1)),
    rgba(0, 0, 0, 0.4);

  z-index: 5;
}
.element {
  background-image: linear-gradient(to top, #050a0f, rgba(255, 255, 255, 0.1));
}

.video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4); /* Kolor i siła przyciemnienia */
  z-index: 5; /* Pomiędzy wideo a treścią */
}

/* 4. Warstwa TREŚCI: Na Wierzchu (z-index: 10) */
.hero-content {
  /* Ustawienie, by treść wypełniła cały obszar i była na wierzchu */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* Gwarantuje, że nagłówki będą widoczne i wycentrowane */
  z-index: 10;
  color: white;
  text-align: center;

  /* Użycie Flexbox do centrowania wszystkich elementów wewnątrz */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

/* Właściwe pozycjonowanie treści na wierzchu filmu */
.content-over-video {
  position: relative;
  z-index: 10; /* Treść jest zawsze nad filmem */
  /* Dodaj tutaj resztę stylów, np. centrowanie tekstu */
}

.video-overlay {
  /* Rozciągnięcie warstwy na cały kontener */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;

  /* KLUCZOWE: Użycie półprzezroczystego tła */
  /* Zmieniając czwartą wartość (0.4) kontrolujesz stopień przyciemnienia: */
  /* 0.0 to brak przyciemnienia, 1.0 to całkowicie czarny obraz. */
  background-color: rgba(0, 0, 0, 0.6);

  /* Pozycjonowanie w stosie: nad wideo (z-index: 1), ale pod treścią (z-index: 10) */
  z-index: 5;
}

/* Upewnij się, że treść jest widoczna na wierzchu */
.hero-content {
  position: relative;
  z-index: 10; /* Musi być wyższe niż overlay (z-index: 5) */
  color: white;
  /* ... reszta stylów ... */
}

@media (max-width: 768px) {
  .Valencia_bg {
    height: auto;
    padding: 100px 20px;
  }
}

.top_spacer {
  margin-top: 150px;
}

/* Button styles */
.button_yellow,
.button_white {
  box-sizing: border-box; /* Sprawia, że 300px to szerokość CAŁKOWITA */
  border: 0;
  padding: 18px 40px;
  color: #09131d;
  width: 300px; /* Teraz jest to szerokość CAŁKOWITA */
}

.button_yellow {
  background-color: #c3a567;
  color: white;
}

.button_yellow:hover {
  background-color: #d8d8d8;
  color: #09131d;
  text-decoration: none;
}

.button_white {
  background-color: white;
}

.button_white:hover {
  background-color: #050a0f;
  color: #ffffff;
  text-decoration: none;
}

button:hover {
  background-color: #ffffff;
}

@media (min-width: 991px) {
  .lang-button {
    width: 50px;
    height: 50px;
  }

  .lang-button img {
    width: 30px;
  }
}

/* Language buttons */
.lang-buttons {
  gap: 0.5rem;
  align-items: center;
  display: flex;
  flex-wrap: wrap;
}

.lang-button {
  display: flex;
  justify-content: center;
  align-items: center;
  /* reszta jak wcześniej */
  border: 2px solid #ffffff;
  background-color: transparent;
  color: #000000;
  border-radius: 50%;
  font-weight: bold;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s;
  user-select: none;
}

.lang-button:hover {
  background-color: #ffffff;
  color: white;
}

.lang-button.active {
  background-color: #b99b5d;
  color: white;
  border-color: #b99b5d;
}

.datepicker {
  width: 280px;
  padding: 42px 16px;
  font-size: 16px;
  border: 2px solid #ffc107;
  border-radius: 10px;
  outline: none;
  transition: transform 0.3s ease;
}
.datepicker:focus {
  border-color: #ffc107;
  transform: translateY(-10px);
}

.datepicker:hover {
  transform: translateY(-10px);
}

/* Layout helpers */
.container {
  max-width: 1300px;
}

@media (min-width: 768px) {
  .w-md-80 {
    width: 92% !important;
  }
}

@media (min-width: 768px) {
  .h-100-md {
    height: 100%;
  }
}

.icon {
  width: 70px;
}

.icon2 {
  width: 40px;
}

.icon4 {
  width: 35px;
 
}

.dark_bg {
  background-color: rgb(49, 49, 49);
}

.hover-up-lightning {
  transition: transform 0.3s ease, filter 0.3s ease;
  filter: brightness(1);
}

.hover-up-lightning:hover {
  transform: translateY(-8px);
  filter: brightness(1.1);
}

.hover-up-lightning2 {
  transition: transform 0.3s ease, filter 0.3s ease;
  filter: brightness(1);
}

.hover-up-lightning2:hover {
  transform: translateY(-10px);
  filter: brightness(1.15);
}

.hover-up-lightning3 {
  transition: transform 0.3s ease, filter 0.3s ease;
  filter: brightness(1);
}

.hover-up-lightning3:hover {
  transform: translateY(-3px);
  filter: brightness(1.15);
}

.hover-up {
  transition: transform 0.3s ease;
}

.hover-up:hover {
  transform: translateY(-10px);
}

.brightening {
  transition: filter 0.3s ease;
  filter: brightness(60%);
}

.brightening:hover {
  filter: brightness(95%);
}

.fade-in-text {
  opacity: 0;
  transform: translateY(2px);
  animation: fadeInUp 1s ease-out forwards;
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.invisible {
  visibility: hidden;
}

#cookie-popup {
  border-radius: 10px;
  position: fixed;
  bottom: 20px;
  width: 90%; /* domyślna szerokość – zajmuje do 90% ekranu */
  max-width: 400px; /* nie przekracza 400px */
  min-width: 280px; /* nie będzie mniejszy niż 280px */
  background-color: #f2f2f2;
  right: 10px;
  padding: 20px;
  border: 1px solid #ccc;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  z-index: 1000;
  display: none;
}

#cookie-popup button {
  border-radius: 10px;
  margin-top: 10px;
  padding: 12px 30px;
  background-color: #c3a567;
  color: rgb(0, 0, 0);
  border: none;
  cursor: pointer;
}

.modal-fullscreen {
  max-width: 100vw;
  margin: 0;
}

@media (min-width: 1020px) {
  .oferta2_img {
    width: 50% !important;
  }
}

@media (max-width: 1020px) {
  .oferta2_img {
    width: 100% !important;
  }
}

@media (max-width: 550px) {
  .oferta2_img {
    max-height: 350px;
  }
}
