.elementor-7168 .elementor-element.elementor-element-55ba67b{--display:flex;}.elementor-7168 .elementor-element.elementor-element-b58b2e1{--display:flex;}/* Start custom CSS for container, class: .elementor-element-55ba67b *//* === SEKCJA HERO - SPECYFICZNE STYLE DLA USDC === */
    /* Zakładamy, że globalne style dla .hero, .hero__layout-wrapper etc. już istnieją w styles.css */

    .hero--usdc .hero__bg {
        position: absolute;
        top: 0; left: 0;
        width: 100%; height: 100%;
        z-index: -2;
        background-color: var(--color-usdc-bg-base, #00529B); /* Ciemnoniebieski bazowy dla USDC */
    }

    .hero--usdc .hero__animation {
        position: absolute;
        top: 0; left: 0;
        width: 100%; height: 100%;
        z-index: -1;
        background: linear-gradient(290deg, #003f7a, #005bab, #2a7dc7, #005bab, #003f7a);
        background-size: 400% 400%;
        animation: usdcHeroWave 30s ease infinite, usdcHeroColorShift 40s alternate infinite;
        opacity: 0.9;
    }

    @keyframes usdcHeroWave {
        0% { background-position: 0% 50%; }
        25% { background-position: 100% 25%; }
        50% { background-position: 100% 75%; }
        75% { background-position: 0% 100%; }
        100% { background-position: 0% 50%; }
    }

    @keyframes usdcHeroColorShift {
        0% { filter: brightness(0.9) saturate(1); }
        50% { filter: brightness(1.1) saturate(1.2); }
        100% { filter: brightness(0.9) saturate(1); }
    }

    .hero--usdc .hero__cta .btn--primary {
        background-color: var(--color-usdc-accent, #2775CA);
        border-color: var(--color-usdc-accent, #2775CA);
        color: var(--color-white, #ffffff);
    }
    .hero--usdc .hero__cta .btn--primary:hover {
        background-color: var(--color-usdc-accent-dark, #1f5a9c);
        border-color: var(--color-usdc-accent-dark, #1f5a9c);
    }

    /* Domyślny .btn--secondary z białą ramką powinien pasować, jeśli nie, odkomentuj i dostosuj: */
    /*
    .hero--usdc .hero__cta .btn--secondary {
        color: var(--color-usdc-accent);
        border-color: var(--color-usdc-accent);
    }
    .hero--usdc .hero__cta .btn--secondary:hover {
        background-color: var(--color-usdc-accent);
        color: var(--color-white);
    }
    */

    .hero--usdc .hero__rate {
        border-left: 3px solid var(--color-usdc-accent, #2775CA);
        background-color: rgba(0, 0, 0, 0.25); /* Nieco ciemniejsze dla lepszego kontrastu */
    }

    /* Kolor ikony USDC w badge, jeśli SVG jest jednokolorowe i chcesz je ostylować przez CSS */
    .hero--usdc .service-badge__icon svg circle[stroke="#2775CA"] { /* Celuje w okrąg z niebieskim obramowaniem */
        stroke: var(--color-white, #ffffff); /* Zmienia obramowanie na białe */
    }
    .hero--usdc .service-badge__icon svg path[stroke="#2775CA"] { /* Celuje w linie dolara */
         stroke: var(--color-white, #ffffff); /* Zmienia linie na białe */
    }
    /* Jeśli ikona ma być cała biała, a SVG jest proste:
    .hero--usdc .service-badge__icon svg {
        fill: var(--color-white, #ffffff);
    }
    */

    /* Dostosowanie ikon w sekcji Benefits dla spójności z akcentem USDC */
    .benefits .benefit-card__icon {
        background-color: rgba(var(--color-usdc-rgb, 39, 117, 202), 0.1); /* Użyj --color-usdc-rgb lub zdefiniuj */
    }
    .benefits .benefit-card__icon svg path,
    .benefits .benefit-card__icon svg circle, /* Dla ikon typu zegar */
    .benefits .benefit-card__icon svg line {
        stroke: var(--color-usdc-accent, #2775CA);
    }
    /* Definicja --color-usdc-rgb w :root jeśli chcesz jej użyć:
       --color-usdc-rgb: 39, 117, 202;
    */
    
    
    
    
    
    
    
    









.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;
    }
}

/* === STYLE DLA STRONY FAQ (Poprawione i z !important) === */

.faq-section { /* Dodatkowa klasa dla sekcji, jeśli potrzebna */
    padding: var(--spacing-xl) 0 var(--spacing-xxl) !important;
}

.faq-container { /* Kontener dla listy FAQ */
    max-width: 800px !important;
    margin: 0 auto !important;
}

.faq__list { /* Lista elementów FAQ */
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}

.faq__item {
    margin-bottom: var(--spacing-md) !important;
    border: 1px solid var(--color-light) !important; /* Użycie zmiennej dla jaśniejszego obramowania */
    border-radius: var(--radius-md) !important;
    overflow: hidden !important; /* Ważne dla animacji max-height */
    background-color: var(--color-white) !important; /* Tło dla całego elementu */
}

.faq__question { /* To jest <button> */
    width: 100% !important;
    text-align: left !important;
    padding: var(--spacing-lg) !important;
    background-color: transparent !important; /* Tło przycisku, dziedziczy z .faq__item */
    cursor: pointer !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    transition: background-color var(--transition-fast), color var(--transition-fast) !important;
    border: none !important;
    color: var(--color-primary) !important; /* Domyślny kolor tekstu pytania */
    font-family: var(--font-heading) !important;
    font-size: 1.125rem !important; /* Rozmiar czcionki pytania */
    font-weight: 600 !important;
}

.faq__question:hover,
.faq__question:focus {
    color: var(--color-accent) !important; /* Turkusowy kolor tekstu i ikony (przez currentColor) przy hover/focus */
    /* background-color: var(--color-light) !important; */ /* Opcjonalne tło przy hover */
    outline: none !important;
}

.faq__question:focus-visible {
    box-shadow: 0 0 0 2px rgba(var(--color-accent-rgb), 0.4) !important;
}

/* Tekst pytania wewnątrz przycisku, jeśli jest w osobnym elemencie, np. span lub h3 */
.faq__question-text {
    flex-grow: 1 !important;
    padding-right: var(--spacing-md) !important; /* Odstęp od ikonki */
     /* Kolor dziedziczony z .faq__question */
}

/* === Style dla ikony +/- === */
/* Kontener dla ikony */
.faq__toggle {
    position: relative !important; /* Kluczowe dla pozycjonowania ::before i ::after */
    width: 16px !important;      /* Szerokość kontenera ikony (można dostosować) */
    height: 16px !important;     /* Wysokość kontenera ikony (można dostosować) */
    flex-shrink: 0 !important;   /* Zapobiega kurczeniu się ikony w kontenerze flex (.faq__question) */
    display: inline-flex !important; /* Ułatwia centrowanie, jeśli potrzebne */
    align-items: center !important;
    justify-content: center !important;
    /* Usuwa potencjalne "duchy" tekstu lub domyślne renderowanie, jeśli element nie jest pustym spanem */
    font-size: 0 !important;
    line-height: 0 !important;
    /* Do debugowania można dodać tło: */
    /* background-color: rgba(255,0,0,0.2); */
}


/* Stan rozwinięty - ikona minus "-" */
.faq__question[aria-expanded="true"] .faq__toggle::after {
    transform: translate(-50%, -50%) rotate(0deg) !important; /* Kreska pionowa obraca się do poziomu */
    opacity: 0 !important; /* Kreska pionowa staje się niewidoczna, zostaje tylko pozioma (::before) jako minus */
}
/* === Koniec stylów dla ikony +/- === */

.faq__answer {
    padding: 0 var(--spacing-lg) !important;
    max-height: 0 !important; /* Stan zwinięty; JS lub CSS dla stanu otwartego musi to nadpisać */
    overflow: hidden !important;
    transition: max-height 0.4s ease-in-out, padding 0.4s ease-in-out !important; /* Płynna animacja */
    color: var(--color-dark) !important;
    font-size: 1rem !important;
    line-height: 1.7 !important;
    /* background-color: var(--color-white) !important; /* Można dodać, jeśli potrzebne jest inne tło niż .faq__item */
}
.faq__toggle::before,
.faq__toggle::after {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: 14px !important;     /* Długość linii tworzących plus/minus */
    height: 2px !important;      /* Grubość linii */
    background-color: currentColor !important; /* Kolor dziedziczony z rodzica (.faq__question) */
    border-radius: 1px !important;
    transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out !important;
}

.faq__toggle::before {
    transform: translate(-50%, -50%) rotate(0deg) !important; /* Kreska pozioma */
}

.faq__toggle::after {
    transform: translate(-50%, -50%) rotate(90deg) !important; /* Kreska pionowa */
    opacity: 1 !important; /* Domyślnie widoczna, tworząc "+" z kreską poziomą */
}

.faq__question[aria-expanded="true"] + .faq__answer,
.faq__item.faq__item--active .faq__answer { /* Obsługa obu metod kontroli przez JS/CSS */
    padding-top: var(--spacing-md) !important;
    padding-bottom: var(--spacing-lg) !important;
    max-height: 1000px !important; /* Wystarczająco duża wartość dla treści. Jeśli JS dynamicznie ustawia scrollHeight, ta linia może być redundantna lub potrzebna jako fallback */
}

.faq__answer p {
    margin: 0 0 var(--spacing-md) 0 !important;
}

.faq__answer p:last-child {
    margin-bottom: 0 !important;
}

.faq__answer a {
    color: var(--color-accent) !important; /* Turkusowe linki */
    text-decoration: underline !important;
    font-weight: 500 !important;
}

.faq__answer a:hover {
    color: var(--color-secondary) !important; /* Kolor :hover dla linków */
}

@media (max-width: 768px) {
    .faq__question {
        font-size: 1rem !important;
    }
    .faq__answer { /* Styl dla samego kontenera odpowiedzi na mobilnych */
        font-size: 0.95rem !important;
    }
    .faq__answer p { /* Jeśli chcesz specyficznie dla paragrafów w odpowiedzi */
         font-size: 0.95rem !important; /* To może być redundantne, jeśli .faq__answer już to ustawia */
    }
}
/* --- Modyfikacje i dodatki dla Hero Section --- */

/* Istniejący .hero .container może wymagać poniższych, jeśli nie jest już flex */
.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 */