/* ===================== RESPONSIVE DESIGN WCAG AAA ===================== */
@media (max-width: 1100px) {
    .nav-menu li {
        margin: 0 8px;
    }
    
    .nav-menu a {
        font-size: 0.7rem; /* Zwiększony z 0.65rem dla lepszej czytelności */
        letter-spacing: 0.05em; /* Poprawiona czytelność */
    }
    
    .footer-main {
        gap: 25px;
    }
    
    .footer-info {
        gap: 25px;
    }
    
    .footer-map-square {
        flex: 0 0 220px;
        height: 180px;
    }
    
    /* WCAG: Zwiększone rozmiary tekstu dla lepszej czytelności */
    h1, h2, h3, p {
        letter-spacing: 0.01em;
    }
}

@media (max-width: 992px) {
    h1 { 
        font-size: 2.2rem; 
        line-height: 1.3; /* Poprawiony line-height */
    }
    h2 { 
        font-size: 1.8rem; 
        line-height: 1.3;
    }
    
    .hero h1 { 
        font-size: 2.2rem;
        line-height: 1.3;
    }
    
    .services-grid {
        flex-wrap: nowrap;
        gap: 20px; /* Zwiększony gap dla lepszej dostępności */
        overflow-x: auto;
    }
    
    .men-slider-container {
        height: 350px;
    }
    
    .men-slide-text {
        padding: 30px;
    }
    
    .men-slide-text h3 {
        font-size: 1.5rem;
        line-height: 1.4;
    }
    
    .men-slide-text p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    .section-title h2 {
        font-size: 1.6rem;
        padding: 0 15px;
        line-height: 1.3;
    }
    
    .section-title::before,
    .section-title::after {
        width: calc(50% - 100px) !important;
        height: 3px; /* Grubsza linia dla lepszej widoczności */
    }
    
    .section-title p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    /* WCAG: Zwiększone kontrastowe elementy interaktywne */
    button, .btn, .men-slide-btn {
        min-height: 44px; /* Minimalny rozmiar dotykowy */
        min-width: 44px;
    }
}

@media (max-width: 768px) {
    .section { 
        padding: 50px 0; /* Zwiększony padding dla lepszego oddzielenia */
    }
    
    .services {
        padding-bottom: 60px; /* Mniej miejsca na tabletach */
    }
    
    .hero {
        height: 60vh;
        min-height: 400px;
    }
    
    .hero h1 {
        font-size: 2rem;
        line-height: 1.3;
    }
    
    .hero-title {
        font-size: 2rem;
        line-height: 1.3;
    }
    
    .hero-subtitle {
        font-size: 0.75rem; /* Zwiększony z 0.7rem */
        letter-spacing: 0.8em;
        line-height: 1.4;
    }
    
    .hero-content::before,
    .hero-content::after {
        width: calc(50% - 100px);
        height: 3px; /* Grubsza linia */
    }
    
    @keyframes lineDraw {
        to {
            width: calc(50% - 100px);
        }
    }
    
    .hero p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    .services-grid {
        flex-wrap: nowrap;
        gap: 20px; /* Zwiększony z 15px */
        overflow-x: auto;
    }
    
    /* EXCLUDE CAROUSEL FROM RESPONSIVE RULES - carousel has its own responsive in services.css */
    .service-card:not(.services-carousel .service-card) {
        min-height: 250px;
        padding: 20px; /* Zwiększony z 15px */
    }
    
    .service-card:not(.services-carousel .service-card) h3 {
        font-size: 1.2rem; /* Zwiększony z 1.1rem */
        line-height: 1.3;
        margin-bottom: 10px;
    }
    
    .service-card:not(.services-carousel .service-card) p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    .section-dark.for-men {
        padding: 50px 0; /* Zwiększony z 40px */
    }
    
    .men-slider-container {
        height: 500px;
    }
    
    .men-slide-content {
        flex-direction: column;
    }
    
    .men-slide-image {
        flex: 0 0 40%;
    }
    
    .men-slide-text {
        flex: 0 0 60%;
        padding: 30px; /* Zwiększony z 25px */
    }
    
    .men-slide-text h3 {
        font-size: 1.4rem;
        line-height: 1.4;
    }
    
    .men-slide-buttons {
        flex-direction: column;
        gap: 10px; /* Dodany gap dla lepszego rozstawienia */
    }
    
    .men-slide-btn {
        min-width: auto;
        min-height: 44px; /* Minimalny rozmiar dotykowy */
        padding: 12px 24px; /* Zwiększony padding */
    }
    
    .men-slider-nav {
        bottom: 8px; /* Zwiększony z 4px dla lepszej dostępności */
    }
    
    .about-slider-container {
        height: auto;
    }
    
    .about-slide {
        padding: 30px;
    }
    
    .slide-content h3 {
        font-size: 1.5rem;
        letter-spacing: 2px;
        line-height: 1.4;
    }
    
    .slide-content p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    .section-title h2 {
        font-size: 1.5rem;
        padding: 0 12px;
        line-height: 1.3;
    }
    
    .section-title::before,
    .section-title::after {
        width: calc(50% - 90px) !important;
        height: 3px; /* Grubsza linia */
    }
    
    .section-title p {
        font-size: 0.95rem; /* Zwiększony z 0.9rem */
        line-height: 1.6;
    }
    
    .services-container .service-item:nth-child(n) {
        min-width: 150px;
    }
    
    .services-bar .service-icon {
        height: 25px;
        margin-bottom: 8px; /* Dodany margin dla lepszego rozstawienia */
    }
    
    .service-text {
        font-size: 0.7rem;
        line-height: 1.4;
        font-weight: 500;
    }

    /* WCAG: Poprawki dla nawigacji klawiaturowej */
    .men-slider-arrow:focus,
    .men-slide-btn:focus,
    .service-card:focus-within {
        outline: 3px solid var(--primary-light);
        outline-offset: 3px;
    }

    /* Centrowanie nagłówków na mobile */
    .content h2,
    .content-block h2 {
        text-align: center;
    }

    .content h2::after,
    .content-block h2::after {
        left: 50%;
        transform: translateX(-50%);
    }

    /* Asymetryczne sekcje (zdjęcie + tekst) — kolumna na mobile */
    .asymmetric-section {
        flex-direction: column !important;
        gap: 25px;
        margin: 40px 0;
    }

    .asymmetric-image {
        flex: none;
        width: 100%;
        max-width: 100%;
        height: 250px;
    }

    .asymmetric-content {
        padding: 25px 20px;
        min-height: auto;
    }

    .asymmetric-content .card__title {
        font-size: 1.5rem;
        text-align: center;
    }
}

@media (max-width: 576px) {
    .section { 
        padding: 40px 0;
    }
    
    .services {
        padding-bottom: 50px; /* Jeszcze mniej miejsca na mobile */
    }
    
    h1 { 
        font-size: 1.8rem; 
        line-height: 1.3;
    }
    h2 { 
        font-size: 1.5rem; 
        line-height: 1.3;
    }
    
    .hero h1 { 
        font-size: 1.6rem;
        line-height: 1.3;
    }
    
    .services-grid {
        flex-wrap: nowrap;
        gap: 15px;
        overflow-x: auto;
    }
    
    .services-container {
        padding: 0 15px; /* Zwiększony z 10px */
    }
    
    .service-item {
        min-width: 100px;
        padding: 0 8px; /* Zwiększony z 5px */
    }
    
    .service-text {
        font-size: 0.7rem;
        line-height: 1.4;
        font-weight: 500;
    }

    .men-slider-container {
        height: 450px;
    }
    
    .men-slide-image {
        flex: 0 0 35%;
    }
    
    .men-slide-text {
        flex: 0 0 65%;
        padding: 25px; /* Zwiększony z 20px */
    }
    
    .men-slide-text h3 {
        font-size: 1.3rem; /* Zwiększony z 1.2rem */
        line-height: 1.4;
    }
    
    .men-slide-text p {
        font-size: 0.9rem; /* Zwiększony z 0.85rem */
        line-height: 1.6;
    }
    
    .men-slider-arrow {
        width: 40px; /* Zwiększony z 35px */
        height: 40px;
        font-size: 1rem; /* Zwiększony z 0.9rem */
        min-width: 44px; /* Minimalny rozmiar dotykowy */
        min-height: 44px;
    }
    
    .men-slide-btn {
        padding: 12px 20px; /* Zwiększony z 8px 15px */
        font-size: 0.85rem; /* Zwiększony z 0.8rem */
        min-height: 44px;
    }
    
    .section-title h2 {
        font-size: 1.4rem; /* Zwiększony z 1.3rem */
        padding: 0 12px; /* Zwiększony z 10px */
        line-height: 1.3;
    }
    
    .section-title::before,
    .section-title::after {
        width: calc(50% - 80px) !important;
        height: 3px;
        opacity: 0.3;
    }
    
    .section-title p {
        font-size: 0.9rem; /* Zwiększony z 0.85rem */
        line-height: 1.6;
    }
    
    /* WCAG: Zwiększone rozmiary tekstu dla małych ekranów */
    body {
        font-size: 16px; /* Zapewnia bazowy rozmiar dla przeglądarek */
    }
    
    input, button, select, textarea {
        font-size: 16px; /* Zapobiega powiększaniu przez iOS */
    }
}

@media (max-width: 480px) {
    .header-container {
        padding: 12px 10px; /* Zwiększony z 8px */
    }
    
    .mobile-menu-btn {
        left: 10px;
        font-size: 1.3rem;
        min-width: 44px;
        min-height: 44px;
    }
    
    .nav-menu {
        padding-top: 70px;
    }
    
    .hero {
        height: 50vh;
        min-height: 350px;
    }
    
    .hero h1 {
        font-size: 1.6rem;
        line-height: 1.3;
    }
    
    .hero-title {
        font-size: 1.6rem;
        line-height: 1.3;
    }
    
    .hero-subtitle {
        font-size: 0.65rem; /* Zwiększony z 0.6rem */
        letter-spacing: 0.6em;
        line-height: 1.4;
    }
    
    .hero-content::before,
    .hero-content::after {
        width: calc(50% - 80px);
        height: 3px; /* Grubsza linia */
    }
    
    @keyframes lineDraw {
        to {
            width: calc(50% - 80px);
        }
    }
    
    .about-slider-container {
        height: auto;
        display: flex;
        flex-direction: column;
    }

    .about-slider {
        flex: 1;
    }
    
    .about-slide {
        padding: 25px; /* Zwiększony z 20px */
    }
    
    .slide-content h3 {
        font-size: 1.4rem; /* Zwiększony z 1.3rem */
        letter-spacing: 1px;
        line-height: 1.4;
    }
    
    .slide-content p {
        font-size: 0.9rem; /* Zwiększony z 0.85rem */
        line-height: 1.6;
    }
    
    .section-title h2 {
        font-size: 1.3rem; /* Zwiększony z 1.2rem */
        padding: 0 10px; /* Zwiększony z 8px */
        line-height: 1.3;
    }
    
    .section-title::before,
    .section-title::after {
        width: calc(30%) !important;
        opacity: 0.3;
        height: 3px;
    }
    
    .services-container .service-item:nth-child(n) {
        min-width: 120px;
    }
    
    .services-bar .service-icon {
        height: 22px; /* Zwiększony z 20px */
        margin-bottom: 6px;
    }
    
    .service-text {
        font-size: 0.65rem;
        line-height: 1.4;
        font-weight: 500;
    }

    /* Asymetryczne sekcje — mniejsze na 480px */
    .asymmetric-section {
        gap: 20px;
        margin: 30px 0;
    }

    .asymmetric-image {
        height: 200px;
    }

    .asymmetric-content {
        padding: 20px 15px;
    }

    .asymmetric-content .card__title {
        font-size: 1.3rem;
    }
    
    /* WCAG: Poprawki dla bardzo małych ekranów */
    .service-card:not(.services-carousel .service-card),
    .men-slide-text,
    .about-slide {
        padding: 15px; /* Zapewnia odpowiedni padding dla dotyku */
    }
    
    /* Zwiększone odstępy dla lepszej czytelności */
    h1, h2, h3, p {
        margin-bottom: 12px;
    }

    li {
        margin-bottom: 4px;
    }

    /* Justify -> left na wąskich ekranach */
    .content p,
    .content-block p {
        text-align: left;
    }

    /* Floaty wyłączone na mobile */
    .content-block img.float-left,
    .content-block img.float-right {
        float: none !important;
        display: block;
        margin: 0 auto 20px;
    }
}

/* WCAG: Dodatkowe media query dla preferencji użytkownika */
@media (prefers-reduced-motion: reduce) {
    @media (max-width: 768px) {
        .hero-content::before,
        .hero-content::after {
            animation: none;
            transition: none;
        }
        
        @keyframes lineDraw {
            to {
                width: 0;
            }
        }
    }
}

@media (prefers-contrast: high) {
    @media (max-width: 768px) {
        .section-title::before,
        .section-title::after,
        .hero-content::before,
        .hero-content::after {
            background-color: #000000 !important;
            height: 3px;
            opacity: 1;
        }
        
        .service-card,
        .men-slide-text,
        .about-slide {
            border: 2px solid #000000;
        }
    }
}

/* WCAG: Poprawki dla orientacji landscape na mobile */
@media (max-height: 500px) and (orientation: landscape) {
    .hero {
        min-height: 300px;
        height: auto;
        padding: 40px 0;
    }
    
    .header-nav.active {
        max-height: 80vh;
        overflow-y: auto;
    }
    
    .service-card {
        min-height: 200px;
    }
}

/* WCAG: Zwiększenie czytelności dla użytkowników zwiększających tekst */
@media (min-width: 768px) {
    .service-text {
        font-size: clamp(0.6rem, 1vw, 0.8rem);
    }
    
    .nav-menu a {
        font-size: clamp(0.7rem, 0.8vw, 0.85rem);
    }
}
