/* Általános box-sizing minden elemre */
*, *::before, *::after {
    box-sizing: border-box;
}

/* Változó a navbar magassághoz (állítsd, ha nem 72px!) */
:root {
    --navbar-height: 72px;
}

/* Általános stílusok */
body {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    background-color: #f4f7f6;
    margin: 0;
    line-height: 1.6;
    color: #333;
}

/* Navigációs sáv stílusok */
.navbar {
    transition: background-color 0.3s ease-in-out;
}

/* Hero szekció */

.hero {
  height: 100vh; /* Teljes nézetablak magasság */
  position: relative;
  color: #fff; /* Szövegszín */

  /* Háttérkép beállítások - ASZTALI NÉZET */
  background-image: url('images/bűvész-háttérkép.jpg'); /* <<< ITT GYŐZŐDJ MEG A HELYES KÉP ELÉRÉSI ÚTJÁRÓL! */
  background-size: cover; /* Lefedje a területet, arányok megtartásával */
  background-position: top center; /* Középre igazított háttér */
  background-repeat: no-repeat; /* Ne ismétlődjön */
  background-attachment: fixed; /* Parallax hatás asztalon */
}

/* Átfedő réteg a háttérkép sötétítésére (jobb szövegkontraszt) */
.hero .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* Fekete, 50%-os átlátszósággal */
  z-index: 1; /* Az overlay a háttérkép felett, de a tartalom alatt van */
}

/* Hero szekció tartalmi konténere */
.hero .hero-content {
  position: relative; /* Hogy az overlay felett jelenjen meg */
  z-index: 2;
  width: 100%; /* A Bootstrap ps-5 a szülő .hero elemen van, így a hero-content nem igényel külön bal oldali paddingot itt */
  /* Ha a Bootstrap ps-5 helyett itt szeretnéd a paddingot:
     padding-left: 3rem; // Vagy amennyi szükséges
     max-width: 1200px; // Opcionális, ha korlátozni szeretnéd a tartalom szélességét nagy képernyőn
     margin-left: 0; // Ha a ps-5 helyett itt van padding
  */
}

/* Címsor a hero szekcióban */
.hero h1 {
  font-size: 4.5rem; /* Nagyobb betűméret asztalon (Bootstrap display-4 hasonló méretű) */
  font-weight: bold;
  margin-bottom: 0.5em; /* Térköz a címsor alatt */
  line-height: 1.2;
}

/* Alcím/leírás a hero szekcióban */
.hero .lead {
  font-size: 1.25rem; /* Bootstrap .lead osztályhoz hasonló méret */
  margin-bottom: 1.5em; /* Térköz az alcím alatt */
}

/* Gomb a hero szekcióban */
.hero .btn-light.btn-lg { /* Specifikusabb szelektor, ha Bootstrapet használsz */
  padding: 0.75rem 1.5rem;
  font-size: 1.1rem;
  /* Egyéb gomb stílusok, ha szükséges */
}


/* Mobil optimalizáció (767.98px alatt) ------------------------------------ */
@media (max-width: 767.98px) {
  .hero {
    height: auto; /* Magasság igazodjon a tartalomhoz */
    min-height: 70vh; /* Minimum magasság, hogy azért látványos maradjon, de ne legyen túl nagy üres tér */
    background-attachment: scroll; /* Parallax kikapcsolása mobilon (teljesítmény és kompatibilitás) */
    /* A HTML-ben lévő ps-5 (padding-left: 3rem) lehet sok mobilon.
       Itt felülírhatod, vagy használhatsz reszponzív Bootstrap padding osztályokat a HTML-ben, pl. ps-5 ps-md-2.
       Most felülírjuk a paddingot teljesen: */
    padding: 80px 20px; /* Felső/alsó és oldalsó belső térközök mobilon */
    text-align: center; /* Szöveg középre igazítása mobilon */
  }

  .hero .hero-content {
    /* Mivel a .hero text-align: center;, a hero-content örökli, vagy itt is beállíthatod. */
    /* A width: 100% továbbra is jó. */
  }

  .hero h1 {
    font-size: 2.5rem; /* Kisebb betűméret a címsornak mobilon */
  }

  .hero .lead {
    font-size: 1.1rem; /* Kisebb betűméret az alcímnek mobilon */
    margin-bottom: 2em; /* Nagyobb térköz a gomb előtt */
  }

  .hero .btn-light.btn-lg {
    padding: 0.6rem 1.2rem; /* Kicsit kisebb gomb */
    font-size: 1rem;
  }
}


/* Általános szekció stílusok */
section {
    padding-top: calc(var(--navbar-height) + 2rem);  /* ✅ javított padding-top */
    padding-bottom: 60px;
    scroll-margin-top: 50px;         /* ✅ anchor görgetés eltolás */
}

section h2 {
    text-align: center;
    margin-bottom: 40px;
    padding-bottom: 15px;
    border-bottom: 2px solid #007bff;
    display: inline-block;
    width: auto;
}

/* Műsorok kártya stílusok */
#musorok .card {
    border: none;
    transition: transform 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

#musorok .card:hover {
    transform: translateY(-5px);
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

#musorok .card-title {
    color: #007bff;
}

/* Galéria stílusok */
.gallery-img {
    transition: transform 0.3s ease-in-out, filter 0.3s ease-in-out;
    object-fit: cover;
    height: 250px;
    width: 100%;
}

.gallery-img:hover {
    transform: scale(1.05);
    filter: brightness(0.9);
}

/* Referencia stílusok */

.logo-gallery {
  display: flex;
  flex-wrap: wrap;         /* Tördelés több sorba, ha szükséges */
  justify-content: center; /* Logók középre igazítása a soron belül */
  align-items: center;     /* Logók vertikálisan középre igazítása */
  gap: 2rem 2.5rem;        /* Térköz a logók között (sor és oszlop) */
}

.logo-gallery .logo-item {
  max-height: 55px;        /* Maximális magasság a logóknak az egységesítéshez */
  max-width: 140px;        /* Maximális szélesség, hogy ne nyúljanak túl */
  object-fit: contain;     /* Méretarány megtartása, beleférjen a max méretekbe */
  /* Nincs hover effektus, mivel nem kattinthatóak */
}

/* Mobilos nézet a logógalériának */
@media (max-width: 767.98px) {
  .logo-gallery-title {
    font-size: 1.1rem; /* Kisebb alcím mobilon */
  }

  .logo-gallery {
    gap: 1.5rem 1.5rem;   /* Kisebb térköz mobilon */
  }

  .logo-gallery .logo-item {
    max-height: 40px;    /* Kisebb logók mobilon */
    max-width: 100px;
    opacity: 0.7;        /* Kicsit jobban láthatóak mobilon, ha a grayscale erős */
  }
}

/* A testimonial stílusok (az előző válaszból, ellenőrzésképpen itt is): */
#referenciak .testimonial-card {
 background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  padding: 2rem 2.5rem;
  max-width: 700px;
  border-left: 6px solid #007bff;
  margin-bottom: 1rem;
  
  /* ÚJ ÉS MÓDOSÍTOTT TULAJDONSÁGOK AZ EGYSÉGES MAGASSÁGÉRT ÉS ELRENDEZÉSÉRT */
  min-height: 200px; /* << Ezt az értéket igazítsd a leghosszabb ajánlásodhoz! */
                       /* Nézd meg a leghosszabb szövegű kártyát, és adj neki kényelmes magasságot. */
  display: flex;       /* Flexbox konténerként viselkedik */
  flex-direction: column;/* A belső elemek (card-body) függőlegesen helyezkednek el */
}

#referenciak .testimonial-quote-icon {
  display: block;
  font-size: 3.5rem;
  color: #0d6efd;
  line-height: 1;
  margin-bottom: 0.75rem;
}

#referenciak .testimonial-text {
  color: #343a40;
  font-style: italic;
  line-height: 1.75;
}

#referenciak .testimonial-author {
  color: #343a40;       /* Világosabb szürke (Bootstrap $gray-600) */
  font-size: 0.9rem;    /* Kicsit kisebb betűméret */
  font-weight: 500;     /* Közepesen vastag (nem annyira, mint a bold) */
}

#referenciak .carousel-control-prev-icon,
#referenciak .carousel-control-next-icon {
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 50%;
  padding: 0.5rem;
  width: 2.5rem;
  height: 2.5rem;
}
#referenciak .carousel-control-prev,
#referenciak .carousel-control-next {
    width: 5%;
}

@media (max-width: 767.98px) {
  #referenciak .testimonial-card {
    padding: 1.5rem 1.2rem;
    border-left-width: 5px;
  }

  #referenciak .testimonial-quote-icon {
    font-size: 2.8rem;
    margin-bottom: 0.5rem;
  }

  #referenciak .testimonial-text {
    font-size: 0.95rem;
    line-height: 1.65;
  }

  #referenciak .testimonial-author {
    font-size: 0.85rem;
  }

  #referenciak .carousel-control-prev,
  #referenciak .carousel-control-next {
    width: 8%;
  }


}/* Kapcsolat stílusok */
#kapcsolat .list-group-item {
    transition: background-color 0.3s ease-in-out;
}

#kapcsolat .list-group-item:hover {
    background-color: #e9ecef;
}

#kapcsolat .list-group-item i {
    color: #007bff;
}

/* Lábléc stílusok */
footer a {
    color: #adb5bd;
    text-decoration: none;
    transition: color 0.3s ease-in-out;
}

footer a:hover {
    color: #fff;
}

/* Reszponzív finomhangolások */
@media (max-width: 767.98px) {
    .hero h1 {
        font-size: 2.5rem;
    }

    section {
        padding-top: calc(var(--navbar-height) + 1rem); /* kisebb mobil margó */
        padding-bottom: 40px;
        scroll-margin-top: var(--navbar-height);
    }

    section h2 {
        margin-bottom: 30px;
    }

    .gallery-img {
        height: 200px;
    }

    /* scroll-padding-top alternatív, ha scroll-behavior: smooth */
    /* html { scroll-padding-top: 65px; } */
}

@media (min-width: 768px) and (max-width: 991.98px) {
    .gallery-img {
        height: 220px;
    }

    section {
        scroll-margin-top: var(--navbar-height);
    }
}

#lightboxOverlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.8);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

#lightboxOverlay img {
    max-width: 90%;
    max-height: 90%;
    box-shadow: 0 0 20px #000;
    border-radius: 8px;
    animation: fadeIn 0.3s ease-in-out;
}

@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* main.css */

/* ... (meglévő CSS kódod) ... */

.kpi-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-top: 30px;
  justify-content: center;
}

.kpi-box {
  flex-grow: 0;
  flex-shrink: 1;
  flex-basis: 200px; /* Ez marad az asztali nézetre */
  background-color: #f8f9fa;
  border: 2px solid #dee2e6;
  border-radius: 10px;
  padding: 20px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0,0,0,0.1);
  transition: transform 0.2s ease;
}

.kpi-box:hover {
  transform: translateY(-4px);
}

.kpi-number {
  font-size: 2rem; /* Asztali betűméret */
  font-weight: 700;
  color: #212529;
}

.kpi-label {
  font-size: 1rem; /* Asztali betűméret */
  font-weight: 500;
  color: #555;
  margin-top: 5px;
}

/* Reszponzív finomhangolások */
@media (max-width: 767.98px) {
  /* ... (egyéb meglévő mobilos szabályaid) ... */

  .kpi-container {
    flex-direction: column; /* A KPI boxok egymás alá kerülnek */
    align-items: center;   /* Középre igazítás a konténeren belül (horizontálisan, ha column) */
    gap: 15px;             /* Kisebb rés a boxok között mobilon */
  }

  .kpi-box {
    flex-basis: auto;      /* Felülírjuk az asztali flex-basis-t */
    width: 85%;            /* A boxok szélessége a konténer 85%-a lesz */
    max-width: 300px;      /* De ne legyenek túl szélesek sem, ha pl. egy tablet álló nézetben még ebbe a media querybe esik */
    padding: 15px;         /* Kisebb padding mobilon */
    /* A margin-bottom egyedi boxokra már nem szükséges a flexbox gap miatt,
       de ha nem gap-et használnál, akkor itt lehetne beállítani. */
  }

  .kpi-number {
    font-size: 1.8rem;     /* Kicsit kisebb betűméret a számnak mobilon */
  }

  .kpi-label {
    font-size: 0.9rem;     /* Kicsit kisebb betűméret a címkének mobilon */
  }
}
