/* =========================================
   MAPA WOJEWÓDZTW – SZKOLENIE UV
   ========================================= */

/* Sekcja + kontener */
.training-map-section {
    padding: 80px 0;
}

.training-map-section .container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* Layout mapy + panelu z instruktorkami */
.training-map-layout {
    display: block; /* domyślnie: brak kolumn, sama mapa */
}

.training-map-left {
    width: 100%;
}

/* Samo SVG z mapą */
.poland-map {
    width: 100%;
    height: auto;
    display: block;
    max-width: none; /* rośnie do szerokości rodzica */
}

/* Duża, wycentrowana mapa PRZED wyborem regionu */
.training-map-section:not(.has-selected-region) .training-map-left .poland-map {
    max-width: 800px;
    margin: 0 auto;
}

/* Prawa kolumna domyślnie ukryta */
.training-map-right {
    display: none;
}

/* Po wybraniu regionu – układ desktopowy 2 kolumny */
@media (min-width: 1024px) {

    .training-map-section.has-selected-region .training-map-layout {
        display: flex;
        gap: 40px;
        align-items: flex-start;
    }

    .training-map-section.has-selected-region .training-map-left {
        flex: 0 0 38%;
        display: flex;
        justify-content: flex-start;
    }

    .training-map-section.has-selected-region .training-map-left .poland-map {
        max-width: 260px;
        margin: 0; /* siedzi przy lewej krawędzi .container, nie ekranu */
    }

    .training-map-section.has-selected-region .training-map-right {
        display: block;
        flex: 1;
    }
}

/* ========= KOLORY / STANY WOJEWÓDZTW ========= */

.region-shape {
    fill: #d8d8d8;
    stroke: #ffffff;
    stroke-width: 1;
    cursor: pointer;
    transition: fill 0.2s ease, transform 0.15s ease;
}

/* województwa z instruktorkami (data-active-regions + JS) */
.region-shape.has-trainers {
    fill: #000000;
}

/* aktywne (kliknięte) województwo */
.region-shape.is-active {
    fill: #760000;
    transform: scale(1.01);
}

/* delikatny hover – tylko kolor, bez wpływu na layout */
.region-shape:hover {
    fill: #7b0000;
}

/* ========= MOBILE: lista województw + przycisk CTA ========= */

.training-map-mobile {
    display: none;
    margin-top: 32px;
}

.voivodeship-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.voivodeship-item {
    border-bottom: 1px solid #e0e0e0;
}

.voivodeship-item button {
    width: 100%;
    padding: 12px 0;
    text-align: left;
    background: none;
    border: none;
    font: inherit;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.voivodeship-item.has-trainers button {
    font-weight: 600;
}


/* MOBILE: tylko lista, bez mapy */
@media (max-width: 767px) {

    .training-map-section .training-map-left,
    .training-map-section .training-map-right {
        display: none !important;
    }

    .training-map-mobile {
        display: block;
    }
}

/* Karta instruktora */

.trainer-card {
    display: flex;
    gap: 24px;
    margin-bottom: 40px;
}

.trainer-photo {
    flex: 0 0 auto;
}

.trainer-photo img {
    display: block;
    max-width: 350px;
    max-height: 350px;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.trainer-body {
    flex: 1 1 auto;
}

.trainer-city {
    font-weight: 600;
    margin: 4px 0 8px;
}

.trainer-bio {
    margin: 0 0 12px;
}

.trainer-contact {
    margin: 0 0 8px;
}

.trainer-social a {
    margin-right: 16px;
    font-weight: 600;
}

/* Mobile – zdjęcie nad tekstem */

@media (max-width: 767px) {
    .trainer-card {
        flex-direction: column;
        align-items: flex-start;
    }

    .trainer-photo img {
        max-width: 100%;
        max-height: 350px;
    }
}

/* ---------------------------
   LAYOUT MAPY – DESKTOP/MOBILE
   --------------------------- */

.training-map-layout {
    margin-top: 40px;
}

/* Desktop: mapa + prawa kolumna */
@media (min-width: 768px) {
    .training-map-layout {
        display: flex;
        gap: 40px;
    }

    .training-map-left {
        flex: 0 0 40%;
    }

    .training-map-right {
        flex: 1;
    }

    .training-map-mobile {
        display: none;
    }
}

/* Mobile: tylko lista województw */
@media (max-width: 767px) {
    .training-map-layout {
        display: none;
    }

    .training-map-mobile {
        margin-top: 24px;
    }
}

/* ---------------------------
   LISTA WOJEWÓDZTW – MOBILE
   --------------------------- */

.voivodeship-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.voivodeship-item {
    border-bottom: 1px solid #DFDFDF;
}

.voivodeship-item button {
    width: 100%;
    padding: 12px 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: none;
    border: none;
    font-family: inherit;
    font-size: 16px;
    cursor: pointer;
}

.voivodeship-item.no-trainers button {
    opacity: 0.4;
    cursor: default;
}

.voivodeship-name {
    font-weight: 600;
}

.voivodeship-count {
    margin-left: 4px;
}

.voivodeship-arrow {
    margin-left: auto;
}

/* ---------------------------
   OVERLAY – MOBILE
   --------------------------- */

.training-map-mobile-overlay {
    position: fixed;
    inset: 0;
    background: #FFFFFF;
    z-index: 9999;
    display: none;
}

.training-map-mobile-overlay.is-open {
    display: block;
}

.training-map-mobile-overlay-inner {
    height: 100%;
    overflow-y: auto;
    padding: 24px 16px 90px;
}

.training-map-mobile-header {
    position: sticky;
    top: 0;
    background: #FFFFFF;
    padding-bottom: 12px;
    margin-bottom: 16px;
}

.training-map-mobile-header h2 {
    margin: 8px 40px 4px 0;
    font-size: 20px;
}

.training-map-mobile-back {
    border: none;
    background: none;
    padding: 0;
    font-family: inherit;
    font-size: 14px;
    cursor: pointer;
    text-decoration: underline;
}

.training-map-mobile-close {
    position: absolute;
    top: 16px;
    right: 16px;
    border: none;
    background: none;
    font-size: 24px;
    cursor: pointer;
}

/* ---------------------------
   KARTY INSTRUKTOREK
   --------------------------- */

.trainer-card {
    display: flex;
    gap: 16px;
    margin-bottom: 32px;
}

.trainer-photo {
    flex: 0 0 auto;
}

.trainer-photo img {
    display: block;
    width: 100%;
    max-width: 350px;
    max-height: 350px;
    object-fit: cover;
}

.trainer-body h3 {
    margin: 0 0 4px;
}

.trainer-city {
    margin: 0 0 8px;
    font-weight: 600;
}

.trainer-bio {
    margin: 0 0 8px;
}

.trainer-contact {
    margin: 0 0 8px;
}

.trainer-social a {
    margin-right: 12px;
}

/* Mobile – mniejszy avatar, treść po prawej */
@media (max-width: 767px) {
    .trainer-card {
        align-items: flex-start;
    }

    .trainer-photo {
        flex: 0 0 80px;
    }

    .trainer-photo img {
        max-width: 80px;
        max-height: 80px;
    }
}

/* Prawa kolumna – widok startowy z listą województw (desktop) */

.training-map-right {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
}

.training-map-voivodeships-desktop {
    width: 100%;
}

.training-map-heading h2 {
    font-size: 1.5rem;
    margin-bottom: 4px;
}

.training-map-heading p {
    margin: 0 0 16px;
    color: #666666;
    max-width: 360px;
}

/* Widok desktopowy – lista tylko na większych ekranach */
@media (max-width: 991px) {
    .training-map-voivodeships-desktop {
        display: none;
    }
}

/* Klikalna lista województw – desktop */
.training-map-voivodeship-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.training-map-voivodeship-item {
    display: flex;
    align-items: baseline;
    gap: 4px;                  /* nazwa i liczba X stoją obok siebie */
    margin-bottom: 4px;
    font-size: 0.95rem;
    cursor: pointer;           /* ręka przy najechaniu */
}

.training-map-voivodeship-item:hover {
    opacity: 0.85;
}

.training-map-voivodeship-item .voivodeship-name {
    white-space: nowrap;
}

/* liczba zawsze przy nazwie – nie wyrównana do prawej */
.training-map-voivodeship-item .voivodeship-count {
    color: #666666;
    font-size: 0.9em;
    display: inline-block;     /* trzyma się nazwy */
    margin-left: 2px;
}

/* Województwa z instruktorkami – pogrubione */
.training-map-voivodeship-item.has-trainers .voivodeship-name {
    font-weight: 600;
    color: #000000;
}

/* Województwa bez instruktorek – wyszarzone */
.training-map-voivodeship-item.no-trainers {
    color: #999999;
}

/* LIMIT rozmiaru zdjęć instruktorek w panelu mapy */
.training-map-section .trainer-photo {
    width: 100%;
    max-width: 350px;
    height: auto;
    max-height: 350px;
    object-fit: cover;
    display: block;
}

/* Overlay mapy na mobile – gwarancja widoczności i scrolla */
body.map-overlay-open {
    overflow: hidden;
}

.training-map-mobile-overlay {
    display: none;
}

.training-map-mobile-overlay.open,
.training-map-mobile-overlay.is-open,
.training-map-mobile-overlay.active {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 2500;
    background: rgba(0,0,0,0.65);
}

.training-map-mobile-overlay-inner {
    position: absolute;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding: 12px;
    box-sizing: border-box;
}

#training-map-mobile-details {
    width: 100%;
    max-width: 720px;
    background: #fff;
    border-radius: 16px;
    max-height: 92vh;
    overflow-y: auto;
    padding: 18px;
    box-sizing: border-box;
}

/* =========================================================
   MOBILE – OVERLAY MAPY: ZDJĘCIA INSTRUKTOREK
   ========================================================= */

@media (max-width: 768px) {

    /* Karta instruktorki w overlay */
    #training-map-mobile-details .trainer {
        display: flex;
        align-items: flex-start;
        gap: 12px;
    }

    /* Zdjęcie instruktorki – MOBILE */
    #training-map-mobile-details .trainer-photo {
        width: 88px;
        height: 88px;
        max-width: 88px;
        max-height: 88px;
        flex: 0 0 88px;

        border-radius: 12px;
        object-fit: cover;
        display: block;
    }

    /* Treść obok zdjęcia */
    #training-map-mobile-details .trainer-body {
        flex: 1 1 auto;
        min-width: 0;
    }
}
