/* Reset i zmienne */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

:root {
    --bg-main: #f4f4f4;
    --bg-dark: #121212; /* Jeszcze ciemniejszy, metalowy */
    --text-main: #1a1a1a;
    --text-light: #f4f4f4;
    --accent: #d32f2f; /* Czerwony akcent */
    --navbar-bg: rgba(18, 18, 18, 0.98);
}

html {
    scroll-behavior: smooth;
}

body {
    font-family: 'Montserrat', sans-serif;
    background-color: var(--bg-main);
    color: var(--text-main);
    line-height: 1.6;
}

/* Typografia wspólna */
.section-title {
    font-size: 2.5rem;
    font-weight: 900;
    text-align: center;
    margin-bottom: 50px;
    letter-spacing: 3px;
    text-transform: uppercase;
}

.bg-dark {
    background-color: var(--bg-dark);
    color: var(--text-light);
}

/* Nawigacja */
#navbar {
    position: fixed;
    top: 0;
    width: 100%;
    background: var(--navbar-bg);
    padding: 10px 0;
    z-index: 1000;
    box-shadow: 0 4px 15px rgba(0,0,0,0.7);
}

.nav-container {
    max-width: 1400px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
}


/* Styl dla LOGO OBRAZKOWEGO W MENU */
.nav-logo-link {
    display: flex;
    align-items: center;
}

.nav-logo-img {
    height: 115px; /* Kontroluje wielkość logo w pasku u góry */
    width: auto;

    transition: 0.3s;
}

.nav-logo-link:hover .nav-logo-img {
    opacity: 0.7; /* Delikatne przygaszenie po najechaniu myszką (bez czerwonej poświaty) */
}

.nav-links {
    list-style: none;
    display: flex;
    gap: 20px;
    align-items: center;
}

.nav-links a {
    color: #bbb;
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 700;
    text-transform: uppercase;
    transition: 0.2s;
}

.nav-links a:hover {
    color: var(--text-light);
}

.lang-btn {
    background: transparent;
    border: 1px solid #666;
    color: #bbb;
    padding: 5px 10px;
    cursor: pointer;
    font-family: inherit;
    font-size: 0.75rem;
    transition: 0.3s;
}

.lang-btn:hover {
    background: #bbb;
    color: var(--bg-dark);
}

/* =========================================
   POPRAWKI LAYOUTU I WYŚRODKOWANIE
   ========================================= */

/* Sekcje wspólne */
.section {
    padding: 120px 20px;
    display: flex;
    flex-direction: column;
    align-items: center; /* Zmusza całą zawartość sekcji do trzymania się środka */
    width: 100%;
}

/* Grid 2-kolumnowy (np. O zespole, Kontakt) */
.grid-2 {
    width: 100%;
    max-width: 1000px; /* Blokuje rozciąganie na wielkich monitorach */
    margin: 0 auto;    /* Wyśrodkowuje sam grid */
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    align-items: center;
}

/* Koncerty */
.concert-list {
    width: 100%;
    max-width: 800px; /* Koncerty wyglądają najlepiej, gdy są węższe */
    margin: 0 auto;
}

.concert-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid #333;
}

.c-date { font-weight: 900; color: var(--accent); font-size: 1.2rem;}
.c-venue { font-weight: 700; font-size: 1.1rem; }
.c-city { color: #aaa; }

/* Sklep TBA */
.tba-box {
    width: 100%;
    max-width: 600px;
    margin: 0 auto;
    text-align: center;
    padding: 50px;
    border: 2px dashed #444;
}

/* Widget Facebooka */
.fb-widget-container {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

/* Hero Section (Startowa z DUŻYM LOGO) */
.hero-section {
    height: 100vh;
    background-color: var(--bg-dark);
    color: var(--text-light);
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.hero-content {
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Styl dla GŁÓWNEGO DUŻEGO LOGO */
.hero-logo {
    width: 90%;
    max-width: 1000px;
    height: auto;
    margin-bottom: 20px;
}

@keyframes logoGlow {
    from { filter: drop-shadow(0 0 10px rgba(211, 47, 47, 0.6)); }
    to { filter: drop-shadow(0 0 20px rgba(211, 47, 47, 1)); }
}

.subtitle {
    font-size: 1.3rem;
    font-weight: 300;
    margin-bottom: 40px;
    color: #aaa;
    letter-spacing: 1px;
}

/* Przyciski */
.btn-primary, .btn-secondary {
    display: inline-block;
    padding: 15px 35px;
    font-weight: 700;
    text-decoration: none;
    border-radius: 4px;
    transition: 0.3s;
    cursor: pointer;
    border: none;
    text-transform: uppercase;
    font-size: 0.9rem;
    letter-spacing: 1px;
}

.btn-primary {
    background-color: var(--accent);
    color: var(--text-light);
    box-shadow: 0 4px 15px rgba(211, 47, 47, 0.3);
}

.btn-primary:hover {
    background-color: #b71c1c;
    box-shadow: 0 4px 20px rgba(211, 47, 47, 0.5);
    transform: translateY(-2px);
}

.btn-secondary {
    background-color: transparent;
    color: var(--text-light);
    border: 2px solid var(--text-light);
}

.btn-secondary:hover {
    background-color: var(--text-light);
    color: var(--bg-dark);
}

/* Grid i Media */
.grid-2 {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    align-items: center;
}

.responsive-image {
    width: 100%;
    height: auto;
    border-radius: 4px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.5);
}

/* Muzyka i Media - Baza przycisków */
.music-links, .social-icons {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
}

.music-btn, .social-icons a {
    padding: 15px 30px;
    color: #ffffff !important; /* Wymuszamy biały tekst */
    text-decoration: none;
    font-weight: 700;
    border-radius: 50px;
    transition: 0.3s;
    font-size: 0.9rem;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
    text-align: center;
}

/* Animacja podskakiwania dla wszystkich przycisków */
.music-btn:hover, .social-icons a:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.35);
}

/* Odstęp między ikoną FontAwesome a tekstem w przyciskach */
.music-btn i, .social-icons a i {
    margin-right: 8px;
    font-size: 1.1rem;
}

/* --- KOLORY MAREK (Brand Colors) --- */

/* Spotify - Zielony */
.btn-spotify { background-color: #1DB954; }
.btn-spotify:hover { background-color: #1ed760; }

/* Apple Music - Niebieski (wg życzenia) */
.btn-apple { background-color: #007AFF; }
.btn-apple:hover { background-color: #3395ff; }

/* YouTube / YT Music - Czerwony */
.btn-yt { background-color: #FF0000; }
.btn-yt:hover { background-color: #ff3333; }

/* Tidal - Czarny */
.btn-tidal { background-color: #000000; }
.btn-tidal:hover { background-color: #333333; }

/* Facebook - Niebieski FB */
.btn-fb { background-color: #1877F2; }
.btn-fb:hover { background-color: #3b8ef5; }

/* X (Twitter) - Czarny */
.btn-x { background-color: #000000; }
.btn-x:hover { background-color: #333333; }

/* TikTok - Czarny z białą obwódką */
.btn-tiktok {
    background-color: #000000;
    border: 1px solid #333;
}
.btn-tiktok:hover {
    background-color: #222222;
    border-color: #555;
}


/* Instagram - Gradient */
.btn-ig {
    background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}
.btn-ig:hover {
    /* Rozjaśnienie całego gradientu przy najechaniu */
    filter: brightness(1.15);
}

/* Formularz Kontaktowy */
.contact-form {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.contact-form input, .contact-form textarea {
    width: 100%;
    padding: 18px;
    border: 1px solid #ddd;
    font-family: inherit;
    border-radius: 4px;
    background: #fff;
}

/* Stopka */
footer {
    text-align: center;
    padding: 30px;
    background: #000;
    color: #666;
    font-size: 0.85rem;
    border-top: 1px solid #1a1a1a;
}

/* Telefony */
@media (max-width: 992px) {
    .nav-links { display: none; }
    .nav-container { justify-content: center; }

    .hero-logo { max-width: 400px; }
    .grid-2 { grid-template-columns: 1fr; text-align: center;}

    .concert-item { flex-direction: column; gap: 10px; text-align: center; padding: 30px 0;}
}

/* --- POPRAWKI DLA MAŁYCH EKRANÓW (TELEFONY) --- */
@media (max-width: 480px) {
    .section-title {
        font-size: 1.8rem;      /* Zmniejszamy rozmiar czcionki */
        letter-spacing: 1px;    /* Zmniejszamy odstępy między literami */
        hyphens: auto;          /* Pozwala na dzielenie wyrazów z myślnikiem, jeśli to konieczne */
        word-wrap: break-word;  /* Zapobiega wychodzeniu tekstu poza ekran */
    }
}

/* --- WYRÓŻNIONY PARTNER W STOPCE --- */
.partner-badge {
    display: inline-block;
    background-color: #111; /* Ciemne tło, odcina się od stopki */
    border: 1px solid #333; /* Delikatna ramka */
    padding: 12px 25px;
    border-radius: 6px;
    font-size: 0.95rem;
    color: #aaa;
    letter-spacing: 0.5px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.5);
}

.partner-link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 900; /* Gruby, wyraźny tekst */
    margin-left: 8px;
    text-transform: uppercase;
    transition: all 0.3s ease;
}

.partner-link:hover {
    color: #fff;
    /* Efekt czerwonej poświaty przy najechaniu myszką */
    text-shadow: 0 0 12px var(--accent);
}