.elementor-6631 .elementor-element.elementor-element-e269c8f{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-6631 .elementor-element.elementor-element-e269c8f.e-con{--flex-grow:0;--flex-shrink:0;}.elementor-6631 .elementor-element.elementor-element-8cd2e04{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}:root{--page-title-display:none;}@media(min-width:768px){.elementor-6631 .elementor-element.elementor-element-e269c8f{--width:100%;}}/* Start custom CSS for container, class: .elementor-element-e269c8f */.hero {
    padding-bottom: var(--spacing-xxl);
    position: relative;
    overflow: hidden;
    min-height: calc(80vh - var(--header-height)); /* Upewnij się, że --header-height jest zdefiniowana */
    display: flex;
    align-items: center;
}

.hero--bitcoin { /* Ta klasa może pozostać, jeśli chcesz specyficznych nadpisań dla wariantu bitcoin */
    color: var(--color-white); /* Tekst pozostaje biały, co dobrze kontrastuje z pomarańczem */
}

.hero__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--color-bitcoin-orange, #F7931A); /* Używa Twojej zmiennej */
    z-index: -2; /* Warstwa spodnia tła */
}

.hero__animation {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    /* ZMIANA: Gradient w solidnych kolorach Bitcoina i dodanie animacji */
    background: linear-gradient(
        135deg,
        var(--color-bitcoin-dark, #D97904) 0%,      /* Ciemniejszy pomarańcz */
        var(--color-bitcoin-orange, #F7931A) 50%,   /* Główny pomarańcz Bitcoina */
        var(--color-secondary, #F7B32B) 100%        /* Złoty/pomarańczowy */
    );
    background-size: 250% 250%;                     /* Kluczowe dla ruchu gradientu */
    animation: animatedGradient 20s ease infinite;  /* Kluczowe dla animacji */
    z-index: -1;                                    /* Warstwa animacji nad .hero__bg */
    opacity: 0.9;                                   /* Lekka przezroczystość animacji */
}

.hero__content {
    color: var(--color-white);
    max-width: 650px;
    margin-bottom: var(--spacing-xl);
    position: relative;
    z-index: var(--z-normal); /* Treść nad tłem */
}

.service-badge {
    display: inline-flex;
    align-items: center;
    background-color: rgba(255, 255, 255, 0.15); 
    padding: 0.5rem 1rem;
    border-radius: var(--radius-full);
    margin-bottom: var(--spacing-lg);
}

.service-badge__icon {
    margin-right: var(--spacing-sm);
}

.service-badge__text {
    font-weight: 500;
    font-size: 0.875rem;
}

.hero__title {
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    color: var(--color-white);
    margin-bottom: var(--spacing-md);
    font-weight: 700;
    text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2);
}

.hero__subtitle {
    font-size: clamp(1.125rem, 2vw, 1.25rem);
    margin-bottom: var(--spacing-lg);
    opacity: 0.9; /* Było 0.9, można dostosować */
    line-height: 1.7;
    text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.1);
}

.hero__cta {
    display: flex;
    gap: var(--spacing-md);
    margin-top: var(--spacing-lg);
    flex-wrap: wrap;
}

.hero__rate {
    margin-top: var(--spacing-xl);
    background-color: rgba(255, 255, 255, 0.1);
    padding: var(--spacing-md);
    border-radius: var(--radius-md);
    border-left: 3px solid var(--color-secondary); 
}

.hero__rate-label {
    font-size: 0.875rem;
    opacity: 0.8;
    margin-bottom: var(--spacing-xs);
}

.hero__rate-value {
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: var(--spacing-xs);
}

.hero__rate-amount {
    color: var(--color-light); /* Zgodnie z Twoim kodem. Upewnij się, że --color-light zapewnia dobry kontrast na pomarańczowym tle. Jeśli nie, rozważ var(--color-white) lub inny. */
}

.hero__rate-update {
    font-size: 0.75rem;
    opacity: 0.7;
}

/* --- SEKCJE POZA HERO (dostarczone przez Ciebie) --- */
/* Te style pozostają nietknięte, ponieważ prośba dotyczyła tylko sekcji .hero */

.loading-indicator {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.9);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: var(--z-above);
}

.spinner {
    width: 40px;
    height: 40px;
    border: 4px solid rgba(46, 196, 182, 0.2);
    border-radius: 50%;
    border-top-color: var(--color-accent);
    animation: spin 1s linear infinite;
    margin-bottom: var(--spacing-md);
}

/* @keyframes spin - Zakładam, że jest globalnie lub go nie potrzebujesz w tym fragmencie */
/* Jeśli @keyframes spin jest tylko dla tego loading-indicator, to zostawiam.
   Jeśli jest identyczny z @keyframes animatedGradient, to jeden wystarczy.
   Twoje @keyframes spin jest inne niż @keyframes animatedGradient, więc oba są potrzebne, jeśli oba efekty mają działać. */
@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
} 

.input-with-select {
    display: flex;
    border: 1px solid #ddd;
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.input-with-select:focus-within {
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px rgba(46, 196, 182, 0.2);
}

.select-wrapper {
    position: relative;
}

.select-wrapper::after {
    content: '▼';
    font-size: 0.8rem;
    color: var(--color-dark);
    position: absolute;
    right: var(--spacing-md);
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
}

.network-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.network-badge {
    display: inline-block;
    padding: 6px 12px;
    border-radius: var(--radius-full);
    font-size: 0.875rem;
    background-color: var(--color-light);
    border: 1px solid #eee;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.network-badge:hover {
    background-color: #e9ecef;
    border-color: #ccc;
}

.network-badge.network-badge--active {
    background-color: var(--color-accent);
    color: var(--color-white);
    border-color: var(--color-accent);
}


/* Benefits Section */
.benefits {
    padding: var(--spacing-xxl) 0;
}

.benefits__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-xl);
}

.benefit-card {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    padding: var(--spacing-xl);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-normal), box-shadow var(--transition-normal);
    text-align: center;
}

.benefit-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
}

.benefit-card__icon {
    margin-bottom: var(--spacing-md);
    display: inline-flex;
}

.benefit-card__title {
    font-size: 1.375rem;
    margin-bottom: var(--spacing-sm);
    color: var(--color-primary);
}

.benefit-card__description {
    color: var(--color-dark);
    opacity: 0.8;
    font-size: 0.9375rem;
    line-height: 1.7;
}

/* Process Section */
.process {
    padding: var(--spacing-xxl) 0;
    background-color: var(--color-light);
}

.process__steps {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin-bottom: var(--spacing-xxl);
    flex-wrap: wrap;
}

.process__steps::before {
    content: '';
    position: absolute;
    top: 40px;
    left: 10%;
    right: 10%;
    height: 3px;
    background-color: var(--color-accent);
    opacity: 0.5;
    z-index: var(--z-below);
}

.process__step {
    position: relative;
    z-index: var(--z-normal);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    width: 22%;
    min-width: 200px;
    margin-bottom: var(--spacing-lg);
}

.process__step-number {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background-color: var(--color-accent);
    color: var(--color-white);
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 1.75rem;
    font-weight: 700;
    margin-bottom: var(--spacing-md);
    box-shadow: 0 4px 10px rgba(46, 196, 182, 0.3);
}

.process__step-icon {
    margin-bottom: var(--spacing-md);
    background-color: var(--color-white);
    border-radius: 50%;
    padding: var(--spacing-sm);
    box-shadow: var(--shadow-sm);
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: calc(-1 * var(--spacing-md));
}

.process__step-title {
    font-size: 1.25rem;
    margin-bottom: var(--spacing-sm);
    color: var(--color-primary);
    margin-top: var(--spacing-xs);
}

.process__step-description {
    font-size: 0.9375rem;
    color: var(--color-dark);
    opacity: 0.8;
}

.process__details {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
}

.process__details-item {
    background-color: var(--color-white);
    border-radius: var(--radius-md);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-sm);
}

.process__details-title {
    font-size: 1.25rem;
    margin-bottom: var(--spacing-md);
    color: var(--color-primary);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--color-light);
}

.process__details-content {
    font-size: 0.9375rem;
}

.process__details-list {
    margin: var(--spacing-md) 0;
    padding-left: var(--spacing-lg);
}

.process__details-list li {
    margin-bottom: var(--spacing-sm);
    position: relative;
}

.process__details-list li::before {
    content: '';
    position: absolute;
    left: calc(-1 * var(--spacing-lg));
    top: 0.5em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: var(--color-accent);
}

ol.process__details-list {
    counter-reset: item;
}

ol.process__details-list li {
    counter-increment: item;
}

ol.process__details-list li::before {
    content: counter(item) ".";
    position: absolute;
    left: calc(-1 * var(--spacing-lg));
    top: 0;
    width: auto;
    height: auto;
    background-color: transparent;
    color: var(--color-accent);
    font-weight: 600;
}

.process__cta {
    display: flex;
    justify-content: center;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
    flex-wrap: wrap;
}



/* Contact Section */
.contact {
    padding: var(--spacing-xxl) 0;
    background-color: var(--color-light);
}

.contact__content {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing-xl);
}

.contact__info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
}

.contact__item {
    display: flex;
    align-items: flex-start;
    background-color: var(--color-white);
    padding: var(--spacing-lg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.contact__item-icon {
    margin-right: var(--spacing-md);
    color: var(--color-accent);
}

.contact__item-title {
    font-size: 1.125rem;
    margin-bottom: var(--spacing-xs);
}

.contact__item-note {
    font-size: 0.875rem;
    opacity: 0.7;
    margin-top: var(--spacing-xs);
}

.contact__form-container {
    background-color: var(--color-white);
    padding: var(--spacing-xl);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

.contact__form-title {
    margin-bottom: var(--spacing-lg);
    font-size: 1.25rem;
}

.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: 500;
    font-size: 0.9375rem;
}

.form-group input,
.form-group textarea {
    width: 100%;
    padding: var(--spacing-md);
    border: 1px solid #ddd;
    border-radius: var(--radius-md);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.form-group input:focus,
.form-group textarea:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 2px rgba(46, 196, 182, 0.2);
}

.form-checkbox {
    display: flex;
    align-items: flex-start;
}

.form-checkbox input {
    width: auto;
    margin-right: var(--spacing-sm);
    margin-top: 0.25rem;
}

.form-checkbox label {
    font-size: 0.875rem;
    font-weight: normal;
}



/* Loading animation */
@keyframes shimmer {
    0% {
        background-position: -1000px 0;
    }
    100% {
        background-position: 1000px 0;
    }
}

.loading-shimmer {
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 1000px 100%;
    animation: shimmer 2s infinite linear;
    border-radius: var(--radius-md);
}

/* Responsive styles */
@media (max-width: 1024px) {
    :root {
        --spacing-xxl: 3rem;
    }
    
    .process__steps::before {
        display: none;
    }
    
    .process__step {
        width: 45%;
    }
}

@media (max-width: 768px) {
    
    .header__cta {
        display: none;
    }
    
    
    .hero__cta {
        flex-direction: column;
        align-items: flex-start;
    }
    
    .hero__cta .btn {
        width: 100%;
    }
    
  
    
    .process__step {
        width: 100%;
    }
    
    .contact__content {
        grid-template-columns: 1fr;
    }
    
    .footer__column--logo {
        grid-column: span 1;
    }
    
    .footer__bottom {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media (max-width: 480px) {
    :root {
        --spacing-lg: 1rem;
        --spacing-xl: 1.25rem;
        --spacing-xxl: 2rem;
    }
    
    .section-title {
        font-size: 1.75rem;
    }
    
    .hero__title {
        font-size: 2.25rem;
    }
    
    .hero__subtitle {
        font-size: 1rem;
    }
    
  
    .process__details-item {
        padding: var(--spacing-md);
    }
    
    
}

/* Print styles */
@media print {
    .header, .footer, .back-to-top, .cookie-consent {
        display: none;
    }
    
    main {
        padding-top: 0;
    }
    
    body {
        font-size: 12pt;
        line-height: 1.5;
    }
    
    a {
        text-decoration: underline;
    }
    
    .container {
        max-width: 100%;
        padding: 0;
    }
    
    .hero, .benefits, .calculator-section, .process, .faq, .contact {
        padding: 1cm 0;
        page-break-inside: avoid;
    }
    
    .hero__bg, .hero__animation {
        display: none;
    }
    
    .hero__content {
        color: var(--color-dark);
    }
    
    .hero__title {
        color: var(--color-primary);
    }
    
    .btn {
        border: 1px solid #000;
        padding: 0.5cm;
        text-decoration: none;
    }
}

/* Utility classes */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }
.my-0 { margin-top: 0; margin-bottom: 0; }

.mt-sm { margin-top: var(--spacing-sm); }
.mb-sm { margin-bottom: var(--spacing-sm); }
.my-sm { margin-top: var(--spacing-sm); margin-bottom: var(--spacing-sm); }

.mt-md { margin-top: var(--spacing-md); }
.mb-md { margin-bottom: var(--spacing-md); }
.my-md { margin-top: var(--spacing-md); margin-bottom: var(--spacing-md); }

.mt-lg { margin-top: var(--spacing-lg); }
.mb-lg { margin-bottom: var(--spacing-lg); }
.my-lg { margin-top: var(--spacing-lg); margin-bottom: var(--spacing-lg); }

.mt-xl { margin-top: var(--spacing-xl); }
.mb-xl { margin-bottom: var(--spacing-xl); }
.my-xl { margin-top: var(--spacing-xl); margin-bottom: var(--spacing-xl); }

.hidden { display: none; }
.visible { display: block; }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.justify-center { justify-content: center; }
.justify-between { justify-content: space-between; }
.gap-sm { gap: var(--spacing-sm); }
.gap-md { gap: var(--spacing-md); }
.gap-lg { gap: var(--spacing-lg); }

.w-full { width: 100%; }
.h-full { height: 100%; }

.rounded-sm { border-radius: var(--radius-sm); }
.rounded-md { border-radius: var(--radius-md); }
.rounded-lg { border-radius: var(--radius-lg); }
.rounded-full { border-radius: var(--radius-full); }

.shadow-sm { box-shadow: var(--shadow-sm); }
.shadow-md { box-shadow: var(--shadow-md); }
.shadow-lg { box-shadow: var(--shadow-lg); }

.bg-primary { background-color: var(--color-primary); }
.bg-secondary { background-color: var(--color-secondary); }
.bg-accent { background-color: var(--color-accent); }
.bg-light { background-color: var(--color-light); }
.bg-white { background-color: var(--color-white); }

.text-primary { color: var(--color-primary); }
.text-secondary { color: var(--color-secondary); }
.text-accent { color: var(--color-accent); }
.text-light { color: var(--color-light); }
.text-white { color: var(--color-white); }

.font-bold { font-weight: 700; }
.font-medium { font-weight: 500; }
.font-normal { font-weight: 400; }
.font-light { font-weight: 300; }

.text-sm { font-size: 0.875rem; }
.text-md { font-size: 1rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.5rem; }
.text-3xl { font-size: 1.875rem; }
.text-4xl { font-size: 2.25rem; }


/* Dodatkowe style dla dostępności i kompatybilności między przeglądarkami */

/* Poprawki dla Firefox */
@-moz-document url-prefix() {
    .calculator__select {
        padding-right: 2.5rem;
    }
    
    .select-wrapper::after {
        right: 0.75rem;
    }
}

/* Poprawki dla Safari */
@media not all and (min-resolution:.001dpcm) { 
    @supports (-webkit-appearance:none) {
        .input-with-select {
            overflow: visible;
        }
        
        .calculator__select {
            border-radius: 0 var(--radius-md) var(--radius-md) 0;
        }
    }
}

/* Poprawki dla Edge */
@supports (-ms-ime-align:auto) {
    .calculator__select {
        padding-right: 2rem;
    }
}

/* Poprawki dla IE11 */
@media all and (-ms-high-contrast: none), (-ms-high-contrast: active) {
    .calculator__select {
        padding-right: 2rem;
    }
    
    .nav__dropdown {
        display: none;
    }
    
    .nav__item--dropdown:hover .nav__dropdown {
        display: block;
    }
}

/* Ulepszenia dostępności */
:focus {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

:focus:not(:focus-visible) {
    outline: none;
}

:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
}

/* Ulepszenia dla czytników ekranowych */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* Ulepszenia dla trybu wysokiego kontrastu */
@media (forced-colors: active) {
    .btn--primary,
    .btn--secondary,
    .calculator__tab,
    .network-badge,
    .process__step-number,
    .footer__social-link {
        forced-color-adjust: none;
    }
    
    .btn--primary {
        background-color: ButtonText;
        color: ButtonFace;
    }
    
    .btn--secondary {
        border: 2px solid ButtonText;
    }
}

/* Ulepszenia dla preferencji redukcji ruchu */
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
    }
    
    .benefit-card:hover {
        transform: none;
    }
    
    .footer__social-link:hover {
        transform: none;
    }
    
    .btn:hover {
        transform: none;
    }
}

/* Ulepszenia dla trybu ciemnego */
@media (prefers-color-scheme: dark) {
    .cookie-consent {
        background-color: #222;
        color: #fff;
    }
}

/* Poprawki dla urządzeń dotykowych */
@media (hover: none) {
    .nav__item--dropdown .nav__dropdown {
        display: none;
    }
    
    .nav__item--dropdown .nav__link[aria-expanded="true"] ~ .nav__dropdown {
        display: block;
    }
    
    .btn:hover,
    .calculator__tab:hover,
    .network-badge:hover,
    .benefit-card:hover,
    .footer__social-link:hover {
        transform: none;
    }
}

/* Poprawki dla drukowania */
@media print {
    @page {
        margin: 2cm;
    }
    
    a::after {
        content: " (" attr(href) ")";
        font-size: 0.8em;
        font-weight: normal;
    }
    
    .calculator__content,
    .process__details,
    .faq__answer {
        page-break-inside: avoid;
    }
}

/* Responsive for calculator rows */
@media (max-width: 500px) {
    .calculator__row {
        flex-direction: column !important;
        align-items: stretch !important;
    }
    .calculator__arrow-container {
         transform: rotate(90deg) !important;
         padding-top: 0 !important;
         margin: var(--spacing-xs) auto !important;
         flex-basis: auto !important;
    }
}


.hero .container {
    display: flex; /* Umożliwia wyśrodkowanie .hero__layout-wrapper */
    align-items: center; /* Wyśrodkowanie w pionie */
    width: 100%; /* Upewnij się, że kontener zajmuje całą dostępną szerokość */
}

.hero__layout-wrapper {
    display: flex;
    justify-content: space-between; /* Rozmieszcza elementy z przestrzenią między nimi */
    align-items: center; /* Wyśrodkowanie elementów w pionie */
    width: 100%; /* Pełna szerokość wewnątrz kontenera */
    gap: var(--spacing-xl, 3rem); /* Odstęp między treścią a wykresem, dostosuj --spacing-xl lub wartość */
}

/* Dostosowanie istniejącej klasy .hero__content */
.hero__content {
    flex: 1 1 55%; /* Pozwala treści zająć około 55% dostępnego miejsca */
    max-width: 650px; /* Zachowuje maksymalną szerokość dla czytelności */
    margin-bottom: 0; /* Usuwa dolny margines, flex `gap` lub margines na wrapperze załatwi odstęp */
    z-index: var(--z-normal); /* Upewnij się, że jest nad tłem */
    position: relative; /* Dla z-index */
}

.hero__chart-wrapper {
    flex: 1 1 40%; /* Pozwala wykresowi zająć około 40% miejsca */
    max-width: 550px; /* Maksymalna szerokość dla wykresu, dostosuj wg potrzeb */
    height: 450px;    /* Stała wysokość dla kontenera wykresu, dostosuj wg potrzeb */
    min-height: 350px; /* Minimalna wysokość */
    border-radius: var(--radius-lg, 12px); /* Użyj swoich zmiennych dla zaokrąglenia */
    overflow: hidden; /* Ważne, aby widget TradingView przyjął border-radius kontenera */
    background-color: rgba(255, 255, 255, 0.03); /* Delikatne tło, jeśli potrzebne - dostosuj */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2); /* Subtelny cień dla głębi */
    z-index: var(--z-normal);
    position: relative;
}

/* --- Styl dla responsywności Hero Section --- */
@media (max-width: 992px) { /* Punkt przerwania dla tabletów i mniejszych ekranów */
    .hero__layout-wrapper {
        flex-direction: column; /* Treść nad wykresem */
        text-align: center; /* Wyśrodkowanie tekstu w .hero__content */
    }

    .hero__content {
        flex-basis: auto; /* Automatyczna szerokość po zmianie kierunku flex */
        width: 100%; /* Pełna szerokość */
        max-width: 700px; /* Możesz dostosować max-width dla trybu kolumnowego */
        margin-bottom: var(--spacing-xl, 3rem); /* Odstęp pod treścią przed wykresem */
    }
    
    .hero__cta {
        justify-content: center; /* Wyśrodkowanie przycisków CTA */
    }
    
    .hero__rate {
        margin-left: auto; /* Wyśrodkowanie bloku z kursem */
        margin-right: auto;
        display: inline-block; /* Aby marginesy auto działały */
    }

    .hero__chart-wrapper {
        flex-basis: auto;
        width: 100%; /* Pełna szerokość dla wykresu */
        max-width: 600px; /* Maksymalna szerokość wykresu w trybie kolumnowym */
        height: 350px; /* Mniejsza wysokość na mniejszych ekranach */
    }
}

@media (max-width: 768px) {
     .hero__chart-wrapper {
        height: 300px; /* Jeszcze mniejsza wysokość na telefonach */
    }
    .hero__title {
        font-size: clamp(2.2rem, 4.5vw, 3rem); /* Dostosowanie rozmiaru tytułu */
    }
    .hero__subtitle {
        font-size: clamp(1rem, 1.8vw, 1.125rem); /* Dostosowanie rozmiaru podtytułu */
    }
}/* End custom CSS */