* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background: #010c18;
}



 #loader-scene {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            z-index: 9999;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        /* Kurtyny */
        .curtain {
            position: absolute;
            top: 0;
            width: 50%;
            height: 100%;
            background: #050f1b; /* Kolor kurtyn */
            z-index: -1;
        }
        .curtain.left { left: 0; border-right: 1px solid rgba(0,0,0,0.03); }
        .curtain.right { right: 0; }

        /* Treść Loadera */
        .loader-content {
            text-align: center;
            z-index: 10;
        }

        .counter {
            font-size: 4rem;
            font-weight: 200;
            color: #b97c09;
            letter-spacing: -2px;
            margin-bottom: 15px;
        }

        .progress-container {
            width: 200px;
            height: 2px;
            background: #0000000d;
            margin: 0 auto;
            overflow: hidden;
        }

        .progress-fill {
            width: 0%;
            height: 100%;
            background: #b97c09;
        }


/* Tablety i mniejsze laptopy */
@media (max-width: 1024px) {
    .counter {
        font-size: 8vw;
    }
    .progress-container {
        width: 40vw;
    }
}

/* Smartfony (Portret) */
@media (max-width: 768px) {
    .counter {
        font-size: 15vw; /* Duży, prestiżowy licznik na mobile */
        letter-spacing: -1px;
        margin-bottom: 10px;
    }

    .progress-container {
        width: 60vw; /* Szerszy pasek na telefonie, żeby był czytelny */
        height: 3px; /* Odrobinę grubszy dla lepszej widoczności */
    }
}

/* Bardzo małe ekrany i telefony w poziomie (Landscape) */
@media (max-height: 500px) and (orientation: landscape) {
    .counter {
        font-size: 10vh; /* Na poziomie skalujemy względem wysokości */
        margin-bottom: 5px;
    }
    .progress-container {
        width: 30vw;
    }
}









.hero {
    width: 100%;
    height: 200vh;
    place-content: center;
}

.capsule-section {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100vh;
}

.capsule {
  width: 80vw;
  height: 80vh;
  overflow: hidden;
  border-radius: 22px;
}

.capsule img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: scale(1.05);
}




.heading-reveal {
  overflow: hidden;
  opacity: 0;
}

.split-char {
  display: inline-block;
  transform: translateY(100%);
  opacity: 0;
}



.hero-content {
  width: 100%;
  height: 35vh;
  place-content: center;
  justify-items: start;
}


.hero-hed {
  font-size: 120px;
  color: #ffaa0c;
 font-family: "Arial";
 font-weight: 500;
 text-align: left;
}


.hero-opis {
  width: 65%;
  font-size: 25px;
  color: #ffffff;
  text-align: right;
  position: relative;
  padding-top: 50px;
  left: 30%;
}

.copy {
  position: relative;
  margin-top: 0px;
  line-height: 110%;
  overflow: hidden;
  opacity: 0;
}

.split-line {
  overflow: hidden;
}

.split-parent {
  overflow: hidden;
}



nav {
  width: 100%;
  text-align: center;
  place-content: center;
  height: 30px;
  position: fixed;
  z-index: 9998;
  display: flex;
  gap: 20px;
}


.hover-link {
  background: none;
  color: #000000;
  font-family: "Monument Extended";
  font-size: 20px;
  text-decoration: none;
  display: inline-block;
  position: relative;
  cursor: pointer;
  padding-left: 20px;
}

.hover-link > span {
  overflow: hidden;
  display: block;
  position: relative;
  pointer-events: none;
}

.hover-link > span > span {
  display: inline-block;
}

.hover-link > span > span:nth-of-type(1) {
  transition: 0.45s ease all;
}

.hover-link > span > span:nth-of-type(2) {
  transition: 0.45s ease all;
  transition-delay: 0.07s;
}

.hover-link > span > span > span {
  content: attr(data-text);
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(200%);
}

.hover-link:hover > span > span,
.hover-link:focus > span > span {
  transform: translateY(-200%);
}



.why-us {
  width: 100%;
  height: 110vh;
  place-content: center;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 600px ;
}


.card {
  place-content: center;
  justify-items: left;
  padding-left: 40px;
}


.wrap {
  width: 90%;
  height: 400px;
  border-radius: 10px;
  overflow: hidden;

}

.wrap-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: 0.6s ease;
}

.wrap-img:hover {
  transform: scale(1.1);
}


.why-hed {
  color: #ffffff;
  text-align: left;
  font-size: 40px;
  padding-top: 30px;
  font-weight: 500;
  font-family: 'Arial';
}

.why-opis {
    color: #838282;
  text-align: left;
  font-size: 20px;
  font-weight: 400;
  padding-top: 10px;
  font-weight: 500;
}



.portfolio {
  width: 100%;
  height: 130vh;
  background-color: #fff;
  place-content: center;
  justify-items: center;
}

.portfolio-hed {
  color: #ffffff;
  font-family: 'Arial';
  font-size: 105px;
  font-weight: 500;
  text-align: right;
}

.card-wrapper {
  max-width: 1700px;
  margin-left: 200px ;
  padding: 20px 10px;
  overflow: hidden;
}

.card-list .card-item {
  list-style: none;
}

.card-list .card-item .card-link {
  display: block;
  background: #010c18;
  padding: 12px;
  user-select: none;
  border-radius: 20px;
  text-decoration: none;
  border: 2px solid transparent;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.05);
  transition: 0.2s ease;
}

.card-list .card-item .card-link:active {
  cursor: grabbing;
}



.card-list .card-link .card-image {
  width: 100%;
  border-radius: 10px;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.card-wrapper {
  margin-left: -15px;
}

.label-text {
  font-size: 1.35rem;
}

.checkbox-box {
  width: 30px;
  height: 30px;
}

/* Responsive media query code for small screens */
@media (max-width: 768px) {
  .card-wrapper {
    margin: 0 10px 25px;
  }

  .card-wrapper .swiper-slide-button {
    display: none;
  }
}


.wrap1 {
  width: 600px;
  height:400px;
  overflow: hidden;
}

.wrap2 {
  width: 95%;
  height: 700px;
}

.card1 {
  place-content: center;
  text-align: left;
  height: 600px;
}



.Oferta {
  width: 100%;
  height: 100vh;
  display: grid;
  place-content: center;
  justify-items: center;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0px;
  grid-template-rows: 600px;
}

.pakiet {
  width: 450px;
  height: 100%;
  place-content: center;
  text-align: left;
  box-shadow: 0px 10px 15px 5px #d8d6d6;
  background-color: #ffffff00;
  border-radius: 10px;
}

.pakiet-hed {
  color: #000;
  font-size: 40px;
  font-family: "Arial";
  font-weight: 500;
  padding-bottom: 20px;
}

.pakiet-opis {
  color: #000;
  font-weight: 400;
  font-size: 18px;
}


ul {
  
  font-size: 20px;
  padding: 50px 10px;
}

li {
  padding-bottom: 15px;
  list-style: none;
}


.divider-parent {
  width: 100%;
  height: 20vh;
  display: grid;
  place-items: start center;
}

.divider {
  width: 1px;
  height: 80vh;
  background-color: #d3cdcdf1;
  transform: scaleY(0);
  transform-origin: top;
   
}

.about {
  width: 100%;
  height: 100vh;
  background-color: #010c18;
  display: grid;
  grid-template-columns: 1fr 2fr;
  grid-template-rows: 100vh;
}




.wrap2 {
  width: 450px;
  height:450px;
  opacity: 0;
  margin-left: 100px;
  border-radius: 20px;
  overflow: hidden;
  
}


.about-hed {
  font-family: 'Arial';
  font-size: 45px;
  font-weight: 500;
  color: #fff;
  
}


.right {
  place-content: center;
}







.space {
  width: 100%;
  height: 10vh;
  place-content: center;
  text-align: center;

}



.faq {
    background-color: #010c18;
    color: var(--text-main);
    font-family: 'Inter', sans-serif;
    display: flex;
    justify-content: center;
    align-items: center;
    padding-top: 100px;
    margin: 0;
    width: 100%;
    height: 100vh;
    font-family: 'Arial';
}

.faq-container {
    width: 90%;
    max-width: 900px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.accordion-item {
    background: #010c18;
    border: 1px solid #ffaa0c;
    border-radius: 100px; /* Wygląd pigułki */
    overflow: hidden;
    transition: border-color 0.4s ease, border-radius 0.4s ease;
}

/* Zmniejszamy zaokrąglenie pigułki po otwarciu, żeby lepiej wyglądało z tekstem */
.accordion-item.active {
    border-color: #ffaa0c;
    border-radius: 30px;
}

.accordion-header {
    width: 100%;
    padding: 20px 35px;
    background: none;
    border: none;
    color: #ffaa0c;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-size: 17px;
    font-weight: 500;
}

.icon-box {
    width: 32px;
    height: 32px;
    background: #010c18;
    border: 1px solid #ffaa0c;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}

.accordion-item.active .icon-box {
    transform: rotate(135deg); /* Plus zmienia się w X */
}

/* --- ANIMACJA WYSOKOŚCI --- */
.content-wrapper {
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 1.2s cubic-bezier(0.19, 1, 0.22, 1);
}

.accordion-item.active .content-wrapper {
    grid-template-rows: 1fr;
}

.content1 {
    overflow: hidden;
}

.content1 p {
    padding: 0px 40px 30px 40px;
    margin: 0;
    color: #ffaa0c;
    line-height: 1.6;
}

/* --- STYLE DLA GSAP REVEAL --- */
.line {
    overflow: hidden; /* Kontener dla każdej linii tekstu */
    padding-bottom: 2px;
}


:root {
    --bg: #ffffff;
    --card-bg: #fcfcfc;
    --border: #ffffff;
    --text-main: #000000;
    --text-dim: #000000;
}


.why-us-hed2 {
  width: 100%;
  height: 20vh;
  place-content: start;
  justify-items: left;
}
.why-us-hed3 {
  width: 100%;
  height: 30vh;
  place-content: center;
  justify-items: center;
}






.pricing-section {
    padding: 100px 20px;
    background-color: #010c18;
    display: flex;
    justify-content: center;
    /* Perspektywa jest kluczowa dla efektu GSAP Tilt */
    perspective: 1000px; 
    height: 100vh;
}

.pricing-container {
    display: flex;
    gap: 30px;
    max-width: 1200px;
    width: 100%;
}

.pricing-card {
    flex: 1;
    background: #010c18;
    border: 1px solid #ebebeb;
    border-radius: 16px;
    padding: 40px;
    display: flex;
    flex-direction: column;
    /* transition dla płynnego powrotu ramki po zjechaniu myszką */
    transition: border-color 0.4s ease, box-shadow 0.4s ease;
    transform-style: preserve-3d;
    position: relative;
}

.pricing-card:hover {
    border-color: #ffaa0c;
    /* Subtelny cień tylko na hover, żeby dodać głębi przy tiltcie */
    box-shadow: 0 20px 40px rgba(0,0,0,0.05);
}

.card-num {
    font-size: 0.85rem;
    font-family: 'Arial';
    font-weight: 600;
    color: #707070;
    display: block;
    margin-bottom: 12px;
    letter-spacing: 1px;
}

.card-title {
    font-size: 2.2rem;
    font-family: 'Arial';
    margin: 0 0 12px 0;
    font-weight: 500;
    color: #dad6d1;
}

.card-tagline {
    color: #ffaa0c;
    font-family: 'Arial';
    font-size: 0.95rem;
    margin-bottom: 35px;
    line-height: 1.5;
}

.card-features {
    list-style: none;
    font-family: 'Arial';
    padding: 0;
    margin: 0 0 40px 0;
    flex-grow: 1;
}

.card-features li {
    padding: 14px 0;
    border-bottom: 1px solid #ffffff;
    font-size: 0.9rem;
    color: #ffffff;
    display: flex;
    align-items: center;
}

.card-features li::before {
    content: "+";
    margin-right: 12px;
    color: #ffffff;
    font-weight: 400;
}

.card-btn {
    text-decoration: none;
    background: #b97c09;
    color: #ffffff;
    text-align: center;
    padding: 16px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 0.95rem;
    font-family: 'Arial';
    transition: background 0.3s ease, transform 0.2s ease;
}

.card-btn:hover {
    background: #333333;
    transform: translateY(-2px);
}



/* Responsywność dla tabletów i telefonów */
@media (max-width: 1024px) {
    .pricing-container {
        gap: 20px;
    }
}

@media (max-width: 900px) {
    .pricing-container {
        flex-direction: column;
        align-items: center;
    }
    .pricing-card {
        width: 100%;
        max-width: 550px;
    }
}


.link-container {
  padding: 50px;
  background: #010c18;
  display: flex;
  justify-content: center;
}

.nav-link {
    font-size: 1.2rem;
    color: #e49607;
    border: none;
    background: none;
    text-decoration: none;
    position: relative;
    padding: 4px 0;
    font-family: 'Arial';
    font-weight: 500;
}

.nav-link::after {
    content: '';
    position: absolute;
    width: 100%;
    height: 0.5px;
    bottom: 0;
    left: 0;
    background-color: #e49607;
    
    /* 1. Startujemy z linii niewidocznej (skala 0) */
    transform: scaleX(0);
    
    /* 2. Przy wyjściu myszką (default) linia zwija się do PRAWEJ */
    transform-origin: bottom right;
    
    /* 3. Kluczowy timing - płynny i luksusowy */
    transition: transform 0.5s cubic-bezier(0.5, 1, 0.89, 1);
}

.nav-link:hover::after {
    /* 4. Przy hoverze linia rozwija się do PEŁNEJ szerokości */
    transform: scaleX(1);
    
    /* 5. Ale punktem startu jest LEWA strona */
    transform-origin: bottom left;
}




.contact-full-section {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 10%;
    background: #010c18;
}

.contact-wrapper {
    width: 100%;
    max-width: 1400px;
}

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
}

.main-title {
    font-size: 3.5rem;
    line-height: 1.1;
    font-weight: 700;
    color: #ffaa0c;
}

.italic-text {
    font-style: italic;
    font-weight: 400;
}

/* Formularz */
.clean-form input, 
.clean-form textarea {
    width: 100%;
    border: none;
    border-bottom: 1px solid #b97c09;
    padding: 15px 0;
    margin-bottom: 30px;
    font-size: 0.9rem;
    outline: none;
    background: transparent ;
    font-family: Arial, sans-serif;
    text-transform: uppercase;
}

.clean-form input:focus::placeholder,
.clean-form textarea:focus::placeholder {
    color: #b97c09;
}

/* Zmienia kolor tekstu, który wpisuje użytkownik */
input, textarea {
    color: #b97c09; /* Możesz użyć 'orange' lub konkretnego kodu hex z Twojego projektu */
}

/* Zmienia kolor tekstu pomocniczego (placeholder) */
input::placeholder, textarea::placeholder {
    color: #b97c09;
    opacity: 1; /* Lekko przezroczysty, żeby odróżnić go od wpisanego tekstu */
}

.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}

textarea {
    height: 100px;
    resize: none;
}

/* Checkbox Stylizacja */
.consent-container {
    margin-bottom: 40px;
}

.custom-checkbox {
    display: flex;
    align-items: flex-start;
    cursor: pointer;
}

.custom-checkbox input {
    display: none; /* Ukrywamy stary checkbox */
}

.checkbox-box {
    width: 20px;
    height: 20px;
    border: 1px solid #ffaa0c;
    margin-right: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.3s ease, border-color 0.3s ease;
    flex-shrink: 0;
}

.custom-checkbox input:checked ~ .checkbox-box {
    border-color: #ffaa0c;
}

/* SVG Ptaszek */
.checkmark-svg {
    width: 16px;
    height: 16px;
  
}

.checkmark-svg path {
    stroke-dasharray: 20;
    stroke-dashoffset: 20; /* Ukryty na start */
    stroke: #b97c09;
}

.label-text {
    font-size: 0.75rem;
    color: #b97c09;
    line-height: 1.4;
}



@media (max-width: 1024px) {
    .contact-grid { grid-template-columns: 1fr; }
}

/* --- TABLET (max-width: 1024px) --- */
@media (max-width: 1024px) {
    .hero-hed {
        font-size: 80px; /* Zmniejszenie ogromnego nagłówka */
        width: 100%;
        text-align: center;
    }

    .hero-opis {
        width: 60%;
        left: 18%;
        text-align: center;
        font-size: 23px;
    }

    .about {
        grid-template-columns: 1fr; /* Obrazek nad tekstem */
        grid-template-rows: 1fr 1fr;
        height: auto;
        padding-bottom: 100px;
    }

    .about-hed {
      font-size: 40px;
    }




    .wrap2 {
        margin: 40px auto;
        width: 95%;
    }

    .why-us {
        grid-template-columns: 1fr ; /* Dwie kolumny zamiast trzech */
        height: auto;
        gap: 150px;
    }


    .pricing-card {
      width: 100%;
    }

    .pricing-section {
      height: 205vh;
    }

    .contact-grid {
        grid-template-columns: 1fr; /* Formularz pod tekstem */
        gap: 40px;
    }

    .main-title {
        font-size: 2.5rem;
        font-weight: 500;
    }

       .nav-link {
        font-size: 30px;
    }

    .right {
      padding-left: 10px;
    }

    .wrap {
      height: 550px;
    }


     .why-us-hed3 {
      width: 0%;
      height: 0vh;
      opacity: 0;
    }

    .faq {
      height: 100vh;
    }

    .checkbox-box {
      width: 30px;
      height: 30px;

    }


    .label-text {
      font-size: 1rem;
    }

    .nav-link {
      font-size: 18px;
    }
}

/* --- TELEFON (max-width: 768px) --- */
@media (max-width: 768px) {
    /* Nawigacja - opcjonalnie zmniejszenie fontu */
    .hover-link {
        font-size: 16px;
        padding-left: 10px;
    }

    /* Sekcja Hero */
    .hero {
        height: auto; /* Rezygnujemy z wymuszonego 200vh na rzecz naturalnej wysokości */
        padding-top: 100px;
        place-content: start;
    }

    .hero-content {
      height: 90vh;
    }

    .about {
      padding-bottom: 260px;
    }

    .about-hed {
      font-size: 30px;
      width: 100%;
    }

    .pricing-section {
      height: 300vh;
    }

    .why-us-hed3 {
      width: 0%;
      height: 0vh;
      opacity: 0;
    }



    .hero-hed {
        font-size: 63px; /* Dopasowanie do szerokości telefonu */
        text-align: center;
        padding: 0 20px;
    }

    .hero-opis {
        width: 90%;
        left: 3%;
        text-align: center;
        font-size: 20px;
    }

    .capsule {
        width: 95vw;
        height: 50vh; /* Niższy baner na telefonie */
    }

    /* Sekcja Stacked Cards (karta pod kartą) */
    .card-content {
        grid-template-columns: 1fr; /* Tekst i obrazek w jednej kolumnie */
        height: auto;
    }

    .text {
        padding: 40px 20px;
    }

    .card-hed {
        font-size: 28px;
    }

    .card1-list {
        font-size: 18px;
    }

    .image {
        height: 250px;
    }

    /* Why Us - jedna kolumna */
    .why-us {
        grid-template-columns: 1fr;
        height: auto;
    }

    .card {
        padding: 20px;
        justify-items: center;
    }

    .why-hed {
        font-size: 30px;
        text-align: center;
    }

    .why-opis {
        text-align: center;
    }

    /* Portfolio */
    .portfolio-hed {
        font-size: 50px;
        text-align: center;
    }

    .wrap1 {
        width: 100%; /* Obrazki w portfolio na całą szerokość */
        height: 250px;
    }

    /* Sekcja FAQ */
    .accordion-header {
        font-size: 15px;
        padding: 15px 20px;
    }

    /* Kontakt */
    .contact-full-section {
        padding: 40px 5%;
    }

    .form-row {
        grid-template-columns: 1fr; /* Pola formularza jedno pod drugim */
        gap: 0;
    }

    .main-title1 {
        font-size: 1.8rem;
        text-align: center;
        font-weight: 500;
    }


    .card-wrapper {
        margin-left: 0 !important;
        padding: 10px;
        width: 100%;
    }

    /* Karta musi zajmować pełną dostępną szerokość */
    .card-item {
        width: 100% !important; 
    }

    .card1 {
        height: auto; /* Pozwalamy karcie rosnąć w zależności od treści */
        padding-bottom: 30px;
    }

    /* Kluczowa zmiana: Twój .wrap1 miał sztywne 600px, co psuło slider na telefonie */
    .wrap1 {
        width: 100%;      /* Szerokość na cały ekran telefonu */
        height: 250px;    /* Mniejsza wysokość zdjęcia na mobile */
        max-width: 100%;
    }

    .card-list .card-item .card-link {
        margin: 0 5px;   /* Delikatny odstęp między slajdami */
    }

}





.site-footer {
    padding: 80px 40px 30px;
    background-color: #010c18;
    font-family: sans-serif;
    border-top: 1px solid #b97c09;
}

/* Układ góry: Nagłówek | Menu */
.footer-top-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 80px;
}

.label-light {
    display: block;
    font-size: 7rem;
    color: #cccccc;
    letter-spacing: -1.5px;
    padding-bottom: 20px;
}

.main-title1 {
    font-size: 4rem;
    font-weight: 500;
    margin: 0;
    text-decoration: none;
}

/* Menu górne */
.footer-main-nav ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
    text-align: right;
}

.footer-main-nav a {
    text-decoration: none;
    color: #000000;
    font-size: 1.1rem;
    font-weight: 500;
}

/* DOLNA BELKA - Dane w linii */
.footer-bottom-info {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    border-top: 1px solid #b97c09;
    padding-top: 30px;
}

.newsletter-box {
    font-size: 0.85rem;
}

.input-underline {
    border-bottom: 1px solid #000;
    display: flex;
    margin-top: 5px;
}

.input-underline input {
    border: none;
    outline: none;
    padding: 5px 0;
    width: 150px;
    font-size: 0.85rem;
}

.input-underline button {
    background: none;
    border: none;
    cursor: pointer;
}

/* LINIA Z DANYMI (ZMNIEJSZONA) */
.company-data-line {
    display: flex;
    gap: 40px;
}

.data-item {
    display: flex;
    gap: 10px;
    font-size: 0.8rem; /* Zmniejszony font */
    color: #fff;
}

.data-label {
    font-weight: 700;
    color: #ffffff;
}

.data-text {
    text-decoration: none;
    color: #fff;
}

.footer-socials a {
    text-decoration: none;
    color: #b97c09;
    font-size: 0.85rem;
    font-weight: 500;
}


/* Responsywność */
@media (max-width: 1100px) {
    .footer-bottom-info {
        flex-direction: column;
        align-items: flex-start;
        gap: 30px;
    }
    .company-data-line {
        flex-direction: column;
        gap: 10px;
    }

    .label-light {
        font-size: 3rem;
    }
}






.main-wrapper { 
            display: flex; 
            max-width: 1600px; 
            margin: 0 auto; 
            position: relative;
        }

        /* 1. KOLUMNA TEKSTU */
        .text-col { width: 40%; padding: 0 5%; }
        .section { 
            height: 100vh; 
            display: flex; 
            flex-direction: column; 
            justify-content: center; 
        }
        .h1 { 
          font-size: 65px; 
          line-height: 1.1;
           font-weight: 500;
           color: #ffaa0c;
            margin-bottom: 20px; }


        .p {
           font-size: 18px;
            max-width: 350px; 
            color: #ffffff; 
            line-height: 1.6; }

        /* 2. KOLUMNA LICZNIKA */
        .counter-col {
            width: 20%;
            height: 100vh;
            position: sticky;
            top: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            z-index: 50;
        }
        .big-counter {
            height: 120px; 
            overflow: hidden;
            font-size: clamp(60px, 8vw, 120px);
            font-weight: 900;
            line-height: 120px;
            color: #ffaa0c;
        }
        .counter-rail { display: flex; flex-direction: column; }

        /* 3. KOLUMNA OBRAZU */
        .visual-col { 
            width: 40%; 
            height: 100vh; 
            position: sticky; 
            top: 0; 
            display: flex; 
            align-items: center; 
            padding-right: 5%;
        }
        .canvas-container {
            width: 100%;
            height: 60vh;
            position: relative;
            border-radius: 20px;
            overflow: hidden;
            background: #f5f5f5;
        }
        .slide {
            position: absolute;
            top: 0; left: 0;
            width: 100%; height: 100%;
            background-size: cover;
            background-position: center;
            transform: translateY(100%);
            z-index: 1;
        }
        .slide:first-child { transform: translateY(0); z-index: 2; }

        /* --- RESPONSYWNOŚĆ (MOBILE & TABLET) --- */
        @media (max-width: 1024px) {
            .main-wrapper { flex-direction: column; }
            
            /* Całkowite ukrycie licznika */
            .counter-col { display: none !important; }

            .text-col { width: 100%; order: 2; }
            .section { height: auto; padding: 100px 5%; }
            .copy.h1 { font-size: 3rem; }

            .visual-col {
                width: 100%;
                height: 50vh;
                position: sticky;
                top: 0; /* Obrazek na samą górę */
                order: 1;
                padding: 20px;
                z-index: 10;
                background: var(--bg);
            }
            .canvas-container { height: 100%; }
        }


@media (max-width: 1366px) {
  .hero-opis {
    font-size: 20px !important; 

  }

  .hero-content {
    height: 55vh;
  }


  .card11 {
    height: 80h;
  }

  .card1-list {
    font-size: 17px;
  }

  .about-hed {
    font-size: 30px;
    left: 10%;
    width: 90%;
    top: 10%;
  }
}