:root {
    --bg: #F8F7F5;
    --ink: #0F172A;
    --primary-50: #E7F6FD;
    --primary-100: #D1EFFB;
    --primary-600: #178DC1;
    --primary-700: #1278A6;
    --accent-600: #F35D33;
    --accent-700: #D94F2B;
    --green-500: #70B935;
    --green-700: #2C843E;
    --yellow-500: #FAC822;
    --sky-100: #A8E3F6;
    --card-bg: #fff;
    --border: #E8EEF7;
    --shadow: 0 8px 24px rgba(16, 24, 40, .06);
    --radius: 18px;
}

/* ——— NAV TOGGLE ——— */
/* Desktop: pokazujemy .nav, chowamy .mobile-menu */
.nav {
    display: flex !important;
}

.mobile-menu {
    display: none !important;
}

/* Mobile (≤900px): chowamy .nav, pokazujemy .mobile-menu */
@media (max-width: 900px) {
    .nav {
        display: none !important;
    }

    .mobile-menu {
        display: block !important;
    }
}

/* ——— RESET & BASE ——— */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    margin: 0;
    padding: 0;
    font-family: 'Nunito', sans-serif;
    color: var(--ink);
    background: var(--bg);
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    color: var(--primary-600);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ——— HEADER & NAV ——— */
header {
    position: sticky;
    top: 0;
    background: #fff;
    border-bottom: 1px solid #eef2f7;
    z-index: 60;
}

.nav {
    align-items: center;
    gap: 20px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 12px 20px;
}

/* Brand */
.nav .brand {
    display: flex;
    align-items: center;
    gap: 12px;
    font-weight: 800;
}

.nav img {
    height: 80px;
}

.nav .brand span {
    font-size: 1.25rem;
}

/* Menu items: bez zawijania i bez scrollbara */
.nav ul {
    list-style: none;
    display: flex;
    gap: 16px;
    margin-left: auto;
    padding: 0;
    flex-wrap: nowrap;
    overflow: hidden;
}

.nav li a {
    padding: 10px 12px;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1rem;
    white-space: nowrap;
    color: var(--ink);
}

.nav li a:hover {
    background: #f2f7ff;
}

/* ——— MOBILE DETAILS MENU ——— */
.mobile-menu summary {
    list-style: none;
    cursor: pointer;
    padding: 8px 16px;
    background: var(--card-bg);
    border-radius: 8px;
    font-weight: 700;
}

.mobile-menu summary::-webkit-details-marker {
    display: none;
}

.mobile-menu[open] summary {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.mobile-menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-top: none;
    border-radius: 0 0 8px 8px;
}

.mobile-menu li a {
    padding: 10px 16px;
    font-size: 0.95rem;
    border-bottom: 1px solid var(--border);
}

.mobile-menu li:last-child a {
    border-bottom: none;
}

/* ——— BUTTONS ——— */
.btn {
    background: var(--accent-600);
    color: #fff;
    padding: 12px 18px;
    border-radius: 14px;
    font-weight: 800;
    display: inline-block;
    transition: filter .15s;
}

.btn:hover {
    filter: brightness(0.95);
}

.btn--accent {
    background: var(--primary-600);
}

.btn--accent:hover {
    background: var(--primary-700);
}

/* ——— BANNER ——— */
.banner {
    background: #f7fbff;
    border-bottom: 1px solid #e8eef5;
}

.banner .inner {
    max-width: 1100px;
    margin: 0 auto;
    padding: 8px 20px;
    color: #075985;
    font-weight: 700;
}

/* ——— HERO SECTION ——— */
.hero {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 32px 20px;
    max-width: 1100px;
    margin: 0 auto;
}

.hero .card {
    flex: 1.2;
    background: #f9fcff;
    border: 1px solid #e6eef7;
    border-radius: 24px;
    padding: 24px;
}

.hero h1 {
    font-size: 38px;
    margin-bottom: 14px;
}

.hero p {
    font-size: 18px;
    margin-bottom: 18px;
}

/* >>> zaktualizowane: wyśrodkowanie kafelków/przycisków <<< */
.hero-cta {
    display: flex;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}

.hero-media {
    flex: 1;
    background: linear-gradient(135deg, #e3f2ff, #fff0e7);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: var(--shadow);
}

.hero-media img {
    width: 100%;
    height: auto;
    border-radius: 24px;
    object-fit: cover;
}

/* ——— GRID SECTIONS ——— */
.grid {
    display: grid;
    gap: 18px;
    padding: 16px 20px;
    max-width: 1100px;
    margin: 0 auto;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.card {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: 24px;
    padding: 22px;
    box-shadow: var(--shadow);
}

.card h3 {
    margin-top: 0;
}

/* ——— BADGE ——— */
.badge {
    display: inline-block;
    background: var(--primary-50);
    color: var(--primary-700);
    padding: 6px 10px;
    border-radius: 999px;
    font-weight: 800;
    font-size: 12px;
}

/* ——— KV SECTION ——— */
.kv {
    display: grid;
    gap: 16px;
    align-items: center;
    grid-template-columns: 1fr 1fr;
}

/* ——— CTA SECTION ——— */
.cta {
    background: linear-gradient(120deg, #e8f6ff, #fff5ef);
    border: 1px dashed #cfe7fb;
    border-radius: 24px;
    padding: 24px;
    text-align: center;
    margin: 24px auto;
    max-width: 1100px;
}

.cta h2 {
    margin-bottom: 8px;
}

/* ——— PRICING TABLE ——— */
.table {
    width: 100%;
    border-collapse: collapse;
}

.table th,
.table td {
    border-bottom: 1px solid #eef2f7;
    padding: 10px;
    text-align: left;
}

.notice {
    background: #fff7ed;
    border: 1px solid #ffedd5;
    color: #9a3412;
    padding: 12px;
    border-radius: 12px;
}

/* ——— FAQ ——— */
.faq details {
    border-color: var(--primary-100);
}

.faq details[open] {
    border-color: var(--primary-600);
    box-shadow: 0 0 0 2px var(--primary-50) inset;
}

.faq a {
    color: var(--primary-600);
}

/* ——— FOOTER ——— */
footer {
    background: #fff;
    border-top: 1px solid var(--primary-100);
    color: var(--ink);
    margin-top: 40px;
}

.footer-inner {
    display: grid;
    gap: 18px;
    padding: 28px 20px;
    max-width: 1100px;
    margin: 0 auto;
    grid-template-columns: 2fr 1fr 1fr;
}

footer a {
    color: var(--primary-700);
}

/* ——— BRANDING COLORS ——— */
.brand-text {
    font-weight: 800;
    font-size: 1.5rem;
}

.brand-text--primary {
    color: var(--primary-700) !important;
}

.brand-text--accent {
    color: var(--accent-600) !important;
}

/* ——— MOBILE TWEAKS (≤900px) ——— */
@media (max-width: 900px) {

    /* HERO: kolumna + ograniczenie wielkości nagłówka */
    .hero {
        flex-direction: column;
        gap: 16px;
        padding: 20px;
    }

    .hero .card {
        padding: 16px;
    }

    .hero h1 {
        font-size: clamp(26px, 7vw, 34px);
    }

    .hero p {
        font-size: clamp(15px, 3.8vw, 18px);
        margin-bottom: 14px;
    }

    .hero-cta {
        gap: 12px;
    }

    /* Media pełnej szerokości, z zachowaniem proporcji */
    .hero-media,
    .kv .hero-media {
        width: 100%;
        max-width: 100%;
        padding: 0;
    }

    .hero-media img,
    .kv .hero-media img {
        width: 100%;
        height: auto;
        display: block;
    }

    /* KV w jednej kolumnie */
    .kv {
        grid-template-columns: 1fr;
    }

    /* Karty i CTA bardziej kompaktowe */
    .card,
    .cta {
        padding: 16px !important;
    }

    .card h3,
    .cta h2 {
        font-size: clamp(18px, 5vw, 22px);
        margin-bottom: .75rem;
    }

    .card p,
    .cta p {
        font-size: clamp(14px, 3.8vw, 16px);
        line-height: 1.5;
    }

    /* Stopka: jedna kolumna i ciaśniejsze odstępy */
    .footer-inner {
        grid-template-columns: 1fr !important;
        padding: 16px !important;
        gap: 16px !important;
    }

    .footer-inner>div {
        margin: 0;
    }
}

/* O NAS – obraz w prawej karcie: zawsze zachowuje proporcje i wypełnia */
.kv .hero-media {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(135deg, #e3f2ff, #fff0e7);
    /* ładny fallback */
    /* Proporcje bloku, zanim obraz się załaduje */
    aspect-ratio: 16 / 10;
    min-height: 320px;
    /* desktop */
}

.kv .hero-media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* wypełnij bez zniekształceń */
    display: block;
    border-radius: 24px;
}

/* Mobile – trochę niższa karta i szersze proporcje */
@media (max-width: 900px) {
    .kv .hero-media {
        aspect-ratio: 16 / 9;
        min-height: 220px;
    }
}

/* === Mobile mini-brand w belce menu === */
@media (max-width: 900px) {
    .mobile-menu summary {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 10px 16px;
        background: var(--card-bg);
        border-radius: 12px;
        font-weight: 700;
    }

    .mobile-menu summary::-webkit-details-marker {
        display: none;
    }

    .mobile-brand {
        display: flex;
        align-items: center;
        gap: 8px;
        min-width: 0;
        /* ładniejsze zawijanie w skrajnych szerokościach */
    }

    .mobile-brand img {
        height: 22px;
        /* małe logo */
        width: auto;
        display: block;
    }

    .mobile-brand-text {
        display: inline-flex;
        gap: 4px;
        font-size: 16px;
        /* dokładnie wielkość „Menu” */
        line-height: 1;
        font-weight: 800;
        white-space: nowrap;
    }

    .mobile-brand--primary {
        color: var(--primary-700);
    }

    .mobile-brand--accent {
        color: var(--accent-600);
    }

    .mobile-menu-label {
        font-size: 16px;
        /* jak proszono: tej samej wielkości */
        font-weight: 700;
        color: var(--ink);
    }
}

/* --- MAPA NA STRONIE KONTAKT --- */
.map-embed {
    width: 100%;
    height: 300px;
    /* wysokość mapy – możesz zmienić np. na 400px */
    border-radius: 16px;
    /* zaokrąglenie rogów */
    overflow: hidden;
    box-shadow: var(--shadow);
}

.map-embed iframe {
    width: 100%;
    height: 100%;
    /* iframe dopasuje się do kontenera */
    border: 0;
}

@media (min-width: 900px) {
    .map-embed {
        height: 400px;
        /* wyższa mapa na desktopie */
    }
}

/* --- Dodatkowe poprawki dla Facebook i Blog --- */
.fb-page {
    max-width: 100% !important;
}

.card iframe {
    width: 100%;
    display: block;
}

.card .badge {
    display: block;
    text-align: center;
    margin-bottom: 10px;
}

.day-plan {
    list-style: none;
    padding: 0;
    margin: 0;
}

.day-plan li {
    margin-bottom: 12px;
    line-height: 1.4;
}

.day-plan li strong {
    color: #178DC1;
    /* Twój kolor primary */
    display: inline-block;
    width: 130px;
    /* wyrównanie godzin */
}

.testimonials {
    list-style: none;
    padding: 0;
    margin: 0;
}

.testimonials li {
    margin-bottom: 20px;
    font-style: italic;
    position: relative;
    padding-left: 25px;
}

.testimonials li::before {
    content: "“";
    font-size: 2rem;
    color: #178DC1;
    position: absolute;
    left: 0;
    top: -5px;
}

.testimonials span {
    display: block;
    margin-top: 8px;
    font-size: 0.9rem;
    color: #333;
    text-align: right;
}

/* >>> mobile: przyciski w hero wygodniejsze do kliknięcia <<< */
@media (max-width: 600px) {
    .hero-cta .btn {
        width: 100%;
        text-align: center;
    }
}

.hero-cta {
    display: flex;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
}

.hero-cta .btn {
    min-width: 220px;
    text-align: center;
    font-size: 1.05rem;
    padding: 14px 20px;
    border-radius: 10px;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.hero-cta .btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(0, 0, 0, .08);
}

/* Na telefonach przyciski pod sobą na pełną szerokość */
@media (max-width: 600px) {
    .hero-cta .btn {
        width: 100%;
    }
}

/* === Proces rekrutacji === */
.process { padding: 40px 0 24px; background: var(--bg, #F8F7F5); }
.process__container { max-width: 1100px; margin: 0 auto; padding: 0 16px; }
.process h2 { font-size: 1.6rem; margin: 0 0 16px; }
.process__intro { color: #475569; margin: 0 0 20px; }

.process__steps { counter-reset: step; list-style: none; margin: 0; padding: 0; display: grid; gap: 16px; }
@media (min-width: 900px) { .process__steps { grid-template-columns: 1fr 1fr; } }
.process__step { background: #fff; border: 1px solid var(--border, #E8EEF7); border-radius: 16px; padding: 18px; box-shadow: 0 8px 24px rgba(16,24,40,.06); }
.process__step h3 { margin: 0 0 8px; font-size: 1.1rem; }
.process__step p { margin: 0 0 10px; color: #475569; line-height: 1.55; }

.process__badge { width: 36px; height: 36px; border-radius: 999px; display: inline-grid; place-items: center; font-weight: 800;
  background: var(--primary-100, #D1EFFB); color: var(--primary-700, #1278A6); margin-bottom: 8px; }

.process__actions { display: flex; flex-wrap: wrap; gap: 8px; margin: 8px 0 4px; padding: 0; list-style: none; }
.btn { display: inline-block; padding: 10px 14px; border-radius: 12px; background: var(--primary-600, #178DC1); color: #fff; text-decoration: none; font-weight: 700; }
.btn:hover { background: var(--primary-700, #1278A6); }
.btn--ghost { background: #fff; color: var(--primary-700, #1278A6); border: 1px solid var(--primary-100, #D1EFFB); }
.btn--ghost:hover { background: var(--primary-50, #E7F6FD); }

.process__hint { font-size: .95rem; color: #64748b; }

.process__rules.card { margin-top: 20px; }
.process__rules h3 { margin-top: 0; }
.process__contact { margin-top: 12px; }

.btn--accent {
    background: var(--accent-600, #F35D33);
    border: 1px solid var(--accent-700, #D94F2B);
}

.btn--accent:hover {
    background: var(--accent-700, #D94F2B);
}

/* --- FAQ: niezależne wysokości kafelków --- */
.faq__list {
  display: grid;
  gap: 12px;
}

/* Desktop: przełącz na flex z zawijaniem */
@media (min-width: 900px) {
  .faq__list {
    display: flex;           /* zamiast grid */
    flex-wrap: wrap;
    align-items: flex-start; /* ważne: nie rozciągaj w pionie */
    gap: 12px;
  }
  .faq__item {
    flex: 1 1 calc(50% - 6px); /* 2 kolumny, własna wysokość */
    max-width: calc(50% - 6px);
  }
}

/* --- FAQ: dwie kolumny + większe, wygodniejsze kafelki --- */
@media (min-width: 900px) {
    .faq__list {
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 16px;
        /* odrobinę większy odstęp */
    }

    .faq__item {
        flex: 1 1 calc(50% - 8px);
        /* 2 kolumny */
        max-width: calc(50% - 8px);
    }
}

/* Większe kafelki: padding, min-height i czytelniejsze summary */
.faq details {
    padding: 18px 20px;
    /* było 14px 16px */
    border-radius: 16px;
}

.faq summary {
    font-size: 1.05rem;
    /* subtelnie większy nagłówek */
}

.faq .faq__item {
    min-height: 88px;
    /* minimalna wysokość zamkniętego kafla */
    display: block;
    /* pewne w Safari */
}

/* Po otwarciu nie ograniczaj wysokości */
.faq details[open] {
    min-height: unset;
}

/* Drobny efekt hover dla lepszej „masy” elementu */
.faq details:hover {
    box-shadow: 0 10px 26px rgba(16, 24, 40, .08);
}

/* === FAQ – 2 kolumny jak wcześniej, ale każdy kafelek ma własną wysokość === */

/* Mobile bez zmian (1 kolumna) */

/* Desktop: zamiast grid użyj flex, żeby sąsiad nie wyrównywał wysokości */
@media (min-width: 900px) {
    .faq__list {
        display: flex !important;
        /* nadpisuje grid */
        flex-wrap: wrap;
        align-items: flex-start;
        /* klucz: nie rozciągaj w pionie */
        gap: 16px;
        /* odstęp między kafelkami */
    }

    /* Każdy kafelek zajmuje połowę szerokości (jak wcześniej) */
    .faq__list>.faq__item {
        flex: 0 0 calc(50% - 8px);
        max-width: calc(50% - 8px);
        align-self: flex-start;
        /* wymuś niezależną wysokość */
    }
}

/* Zachowaj „duży” wygląd kafelka (jak wcześniej) */
.faq details.faq__item {
    background: #fff;
    border: 1px solid #e8eef7;
    border-radius: 16px;
    padding: 18px 20px;
    /* „mięsisty” padding jak w poprzedniej wersji */
    box-shadow: 0 8px 24px rgba(16, 24, 40, .06);
    min-height: 88px;
    /* wysokość zamkniętego kafla jak wcześniej */
}

/* Nagłówek kafla */
.faq details.faq__item>summary {
    list-style: none;
    cursor: pointer;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 1rem;
    /* jak wcześniej – możesz podbić do 1.05rem */
}

.faq details.faq__item>summary::-webkit-details-marker {
    display: none;
}

.faq details.faq__item>summary::after {
    content: "▾";
    margin-left: auto;
    transition: transform .2s ease;
}

.faq details.faq__item[open]>summary::after {
    transform: rotate(180deg);
}

/* Treść po rozwinięciu */
.faq details.faq__item .faq__content {
    margin-top: 8px;
    color: #475569;
    line-height: 1.55;
}

/* Po otwarciu tylko ten kafel rośnie – reszta zostaje jak była */
.faq details.faq__item[open] {
    min-height: unset;
}

/* Wyśrodkowanie treści w nagłówkach FAQ */
.faq details.faq__item>summary {
    display: flex;
    justify-content: center;
    /* środek w poziomie */
    align-items: center;
    /* środek w pionie */
    text-align: center;
    /* tekst też wyśrodkowany */
    font-weight: 600;
    font-size: 1rem;
    gap: 8px;
}

/* Strzałka nadal po prawej */
.faq details.faq__item>summary::after {
    margin-left: auto;
    /* odsuwa strzałkę na prawo */
}

.footer-inner {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 20px;
}

.footer-info {
    grid-column: 1 / -1;
    /* tekst zajmie całą szerokość stopki */
    margin-top: 6px;
    font-size: 12px;
    line-height: 1.3;
    color: #6b7280;
    /* możesz zmienić np. na jaśniejszy szary */
}
/* Aktualności: 2 kolumny na desktopie, 1 kolumna na mobile */
.grid--two {
    display: grid;
    gap: 12px;
    grid-template-columns: 1fr;
}

@media (min-width: 900px) {
    .grid--two {
        grid-template-columns: 1fr 1fr;
    }
}