/* ==========================================================================
   1. ZMIENNE (DESIGN TOKENS) & RESET
   ========================================================================== */
:root {
    --primary-text: #1a1a1a;
    --accent-gold: #B08D55;
    --accent-brown: #5D4037;
    --bg-beige: #F9F7F2;
    --bg-dark-beige: #E6DED5;
    --box-bg: #FFF8F0;
    --white: #ffffff;
    --border-color: #e0e0e0;
    
    /* Ustawienia Slidera */
    --box-position: flex-start;
    --box-margin-side: 5%;
    --box-bg-color: rgba(255, 255, 255, 0.9);
    --banner-height: 46.875rem; /* 750px */
}

*, *::before, *::after { 
    margin: 0; 
    padding: 0; 
    box-sizing: border-box; 
}

html {
    font-size: 100%; /* Bazowe 16px */
    scroll-behavior: smooth;
}

body {
    font-family: 'Lato', sans-serif;
    color: var(--primary-text);
    background-color: var(--white);
    line-height: 1.6;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
}

/* Klasa dla SEO - ukrywa wizualnie, czyta dla robotów i screen readerów */
.sr-only {
    position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0, 0, 0, 0); border: 0;
}

h1, h2, h3, h4, .serif-font, .logo, .main-title, .banner-title {
    font-family: 'Playfair Display', serif;
}

a { text-decoration: none; color: inherit; transition: all 0.3s ease; }
ul { list-style: none; }
img, video { max-width: 100%; height: auto; display: block; object-fit: cover; }
input, select, textarea, button { font-family: inherit; }

.container { width: 100%; max-width: 75rem; /* 1200px */ margin: 0 auto; padding: 0 1.25rem; }
.section-padding { padding: 5rem 0; /* 80px */ }
.text-center { text-align: center; }
.star { color: var(--accent-gold); font-size: 1.2rem; vertical-align: middle; }

/* ==========================================================================
   2. BUTTONY
   ========================================================================== */
.btn-primary, .btn-outline, .btn-order {
    display: inline-block;
    padding: 0.9375rem 2.1875rem;
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 2px;
    border: none;
    cursor: pointer;
    text-align: center;
    transition: all 0.3s ease;
}

.btn-primary { background-color: var(--accent-brown); color: #fff; }
.btn-primary:hover { background-color: var(--accent-gold); color: #fff; }

.btn-outline { border: 1px solid var(--accent-brown); color: var(--accent-brown); background: transparent; }
.btn-outline:hover { background: var(--accent-brown); color: #fff; }

.btn-order { background-color: #1a1a1a; color: #fff; border: 1px solid #1a1a1a; position: relative; z-index: 2; }
.btn-order:hover { background-color: transparent; color: #1a1a1a; }

/* ==========================================================================
   3. NAWIGACJA (HEADER & MENU)
   ========================================================================== */
.site-header {
    padding: 1.5rem 0;
    border-bottom: 1px solid #f0f0f0;
    position: sticky;
    top: 0;
    background: rgba(255,255,255,0.98);
    z-index: 1000;
}

.nav-flex { display: flex; justify-content: space-between; align-items: center; }
.logo { font-size: 2rem; font-weight: 700; color: var(--accent-brown); letter-spacing: 1px; text-transform: uppercase; }

/* Desktop Menu */
.main-nav ul { display: flex; gap: 1.875rem; align-items: center; }
.main-nav a { text-transform: uppercase; font-size: 0.8rem; letter-spacing: 1px; color: #555; font-weight: 700; }
.main-nav a:hover, .main-nav a.active { color: var(--accent-gold); }

/* Dropdown (Kolekcje) - BEZWZGLĘDNIE ZWINIĘTE NA STARCIE */
nav ul li.dropdown { position: relative; padding-bottom: 0.625rem; margin-bottom: -0.625rem; }
nav ul li.dropdown .dropdown-menu {
    display: none; /* Ukryte na stałe do momentu interakcji */
    position: absolute; top: 100%; left: 0;
    background-color: var(--white); min-width: 11.25rem;
    box-shadow: 0 15px 35px rgba(0,0,0,0.1); border-top: 2px solid var(--accent-gold);
    z-index: 1000; flex-direction: column; padding: 0.625rem 0;
}
/* Pokazywanie na desktopie po najeździe */
@media (min-width: 901px) {
    nav ul li.dropdown:hover .dropdown-menu { display: flex; }
}
nav ul li.dropdown .dropdown-menu li { width: 100%; }
nav ul li.dropdown .dropdown-menu a {
    padding: 0.75rem 1.5625rem; display: block; font-size: 0.75rem; transition: all 0.3s ease;
}
nav ul li.dropdown .dropdown-menu a:hover { background-color: var(--bg-beige); color: var(--accent-gold); padding-left: 1.875rem; }

/* Mobile Menu Toggle */
.mobile-menu-toggle {
    display: none; background: none; border: none; cursor: pointer;
    flex-direction: column; gap: 6px; padding: 0.625rem; z-index: 1001;
}
.mobile-menu-toggle span {
    width: 30px; height: 2px; background-color: var(--primary-text);
    transition: 0.3s ease; border-radius: 2px;
}
.mobile-menu-toggle.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.mobile-menu-toggle.open span:nth-child(2) { opacity: 0; }
.mobile-menu-toggle.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

.mobile-only-btn { display: none; }
.desktop-only-btn { display: inline-block; }

/* Responsywność Header/Menu */
@media (max-width: 900px) {
    .mobile-menu-toggle { display: flex; }
    .desktop-only-btn { display: none; }
    .mobile-only-btn { display: block; margin-top: 1.25rem; }
    
    .main-nav {
        position: absolute; top: 100%; left: 0; width: 100%;
        background-color: var(--white); box-shadow: 0 15px 30px rgba(0,0,0,0.1);
        border-top: 1px solid #eee;
        display: none; flex-direction: column; padding: 1.25rem 0; z-index: 1000;
    }
    .main-nav.active { display: flex; }
    .main-nav ul { flex-direction: column; width: 100%; }
    
    nav ul li.dropdown { width: 100%; text-align: center; }
    nav ul li.dropdown .dropdown-menu {
        position: relative; box-shadow: none; border: none; background-color: #f9f9f9;
        width: 100%; display: none; padding: 0.625rem 0; margin-top: 0.9375rem;
    }
    /* Pokazywanie na mobile tylko po dodaniu klasy JS */
    nav ul li.dropdown.mobile-open .dropdown-menu { display: flex; }
}

/* ==========================================================================
   4. LAYOUTY / KOMPONENTY GLOBALNE
   ========================================================================== */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.875rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }

/* Banery (Parallax) */
.promo-banner3 { position: relative; height: 50rem; background: url('img/Pola_3.jpg') center/cover; display: flex; align-items: center; justify-content: center; }

/* ==========================================================================
   SEKCJA WIDEO (Wyśrodkowana z paskiem)
   ========================================================================== */
.video-section-centered {
    background-color: var(--bg-beige);
}

.video-text-centered {
    text-align: center;
    max-width: 50rem; /* ok. 800px - zawęża tekst, by wyglądał jak na zdjęciu */
    margin: 0 auto 2.5rem; /* Środkowanie i margines dolny */
}

.video-text-centered h2 {
    font-size: 2.5rem;
    color: var(--accent-brown);
    margin-bottom: 1rem;
    line-height: 1.2;
}

.video-text-centered p {
    color: #666;
    font-size: 1rem;
    line-height: 1.6;
}

/* Kontener odtwarzacza połączony z linkiem */
.video-player-centered {
    max-width: 56.25rem; /* ok. 900px - ogranicza szerokość wideo */
    margin: 0 auto;
    box-shadow: 0 15px 40px rgba(0,0,0,0.15);
    background: var(--white);
    border: 1px solid var(--border-color);
}

/* Pasek z linkiem nad wideo */
.video-top-link {
    display: block;
    padding: 1rem 1.5rem;
    text-transform: uppercase;
    font-size: 0.75rem;
    font-weight: 700;
    color: #333;
    letter-spacing: 1px;
    border-bottom: 1px solid var(--border-color);
}

.video-top-link:hover {
    color: var(--accent-gold);
    background-color: #fcfcfc;
}

.video-player-centered video {
    width: 100%;
    aspect-ratio: 16/9; /* Zabezpiecza przed skakaniem układu (CLS) */
    object-fit: cover;
    display: block;
    background-color: #000;
}

/* Dostosowanie na telefony */
@media (max-width: 768px) {
    .video-text-centered h2 {
        font-size: 2rem;
    }
    .video-top-link {
        font-size: 0.7rem;
        padding: 0.8rem 1rem;
    }
}

/* Best Seller (Split Screen) */
.best-seller { display: grid; grid-template-columns: 1fr 1fr; background-color: var(--accent-gold); color: white; }
.best-seller-img { background: url('img/Pola_kolekcja_aurora.jpg') center/cover; min-height: 31.25rem; }
.best-seller-img2 { background: url('img/Pola_19.jpg') center/cover; min-height: 31.25rem; }
.best-seller-content { padding: 5rem; display: flex; flex-direction: column; justify-content: center; }
.best-seller-content h2 { color: white; font-size: 3rem; margin-bottom: 1.25rem; line-height: 1.1; }
.best-seller-content p { margin-bottom: 1.875rem; opacity: 0.9; }

/* 3 Bloki Tekstowe (Manufaktura itp.) */
.features-text-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.5rem; }
.feature-text-block {
    background-color: var(--white); padding: 2.5rem 1.875rem; border: 1px solid var(--border-color);
    text-align: center; transition: all 0.3s ease;
}
.feature-text-block:hover { transform: translateY(-10px); box-shadow: 0 15px 35px rgba(0,0,0,0.05); border-color: var(--accent-gold); }
.feature-icon { display: block; font-size: 2rem; color: var(--accent-gold); margin-bottom: 1.25rem; }
.feature-text-block h3 { font-size: 1.5rem; color: var(--accent-brown); margin-bottom: 0.9375rem; }
.feature-text-block p { font-size: 0.95rem; color: #666; line-height: 1.7; }

/* Poziomy tekst cytat */
.horizontal-text-block { background-color: #ffffff; border-top: 1px solid #f9f9f9; border-bottom: 1px solid #f9f9f9; }
.horizontal-text-block .block-title { font-size: 2.5rem; color: var(--accent-brown); margin: 0.9375rem 0 1.5625rem; }

/* ==========================================================================
   5. SEKCJE SPECYFICZNE (HOME)
   ========================================================================== */
/* Hero Slider */
.luxury-hero {
    position: relative; width: 100%; height: var(--banner-height); overflow: hidden;
    display: flex; align-items: center; justify-content: var(--box-position); 
}
.slider-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 0; }
.slide {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background-size: cover; background-position: center; opacity: 0;
    transition: opacity 1.5s ease-in-out, transform 6s ease; transform: scale(1);
}
.slide.active { opacity: 1; transform: scale(1.04); }
.info-card {
    position: relative; z-index: 10; width: 100%; max-width: 31.25rem;
    background-color: var(--box-bg-color); padding: 3.75rem 2.5rem; text-align: center;
    margin: 0 var(--box-margin-side); box-shadow: 0 15px 40px rgba(0,0,0,0.1); backdrop-filter: blur(2px);
}
.info-card::after {
    content: ''; position: absolute; top: 15px; left: 15px; right: 15px; bottom: 15px;
    border: 1px solid rgba(0, 0, 0, 0.15); pointer-events: none;
}
.promo-label { display: block; font-size: 0.85rem; letter-spacing: 2px; text-transform: uppercase; color: #666; margin-bottom: 0.9375rem; }
.main-title { font-family: 'Cinzel', serif; font-size: 3.5rem; color: #1a1a1a; margin-bottom: 0.625rem; line-height: 1; }
.price-tag { font-family: 'Cinzel', serif; font-size: 1.5rem; color: #1a1a1a; margin-bottom: 0.3125rem; }
.price-old { text-decoration: line-through; font-size: 1rem; color: #999; margin-right: 0.625rem; }
.date-info { font-size: 0.8rem; color: #555; margin-bottom: 2.1875rem; font-style: italic; }

/* Wybrane Kolekcje (Ramki) */
.collections-frame-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.5rem; text-align: center; }
.flex-center-heading { display: flex; align-items: center; justify-content: center; gap: 0.9375rem; color: var(--accent-brown); }
.collections-frame-grid h4 { margin-top: 0.9375rem; font-size: 1.5rem; color: var(--primary-text); }
.collection-subtext { font-size: 0.85rem; color: #888; text-transform: uppercase; letter-spacing: 1px; }
.frame-box { border: 1px solid var(--accent-gold); padding: 0.9375rem; transition: transform 0.3s ease; }
.frame-box:hover { transform: translateY(-5px); }
.frame-box img { width: 100%; height: 18.75rem; object-fit: cover; display: block; }

.frame-box_2 {
    border: 1px solid var(--accent-gold); padding: 0.9375rem; transition: transform 0.3s ease;
	width: 100%;
    /* Ustawia proporcje pionowego prostokąta. 
       Dla poziomego możesz użyć np. 4 / 3 lub 16 / 9 */
    aspect-ratio: 4 / 5; 
    overflow: hidden; /* Ukrywa fragmenty zdjęcia wychodzące poza ramkę */
    position: relative;
	
}

.frame-box_2 img {
    width: 100%;
    height: 100%;
    /* 'cover' sprawia, że zdjęcie idealnie wypełnia prostokąt bez zniekształceń proporcji */
    object-fit: cover; 
    display: block;

}

.frame-box:hover { transform: translateY(-5px); }

/* Sale Square */
.sale-square-section { background: #fff; padding: 6.25rem 1.25rem; display: flex; align-items: center; justify-content: center; gap: 5rem; }
.sale-text-block { max-width: 21.875rem; }
.sale-text-block h3 { font-size: 2.5rem; margin-bottom: 1.25rem; color: var(--accent-brown); }
.sale-text-block p { color: #666; margin-bottom: 1.875rem; line-height: 1.6; }
.sale-square {
    background: #1a1a1a; color: white; width: 18.75rem; height: 21.875rem;
    display: flex; align-items: center; justify-content: center; text-align: center;
    font-size: 2.5rem; font-family: 'Playfair Display', serif; line-height: 1.3;
}
.sale-highlight { font-style: italic; color: var(--accent-gold); }

/* Sekcja eco-hero */
.eco-hero {
    background-color: var(--bg-beige);
    padding: 100px 20px;
    border-bottom: 1px solid var(--border-color);
}

.eco-badge {
    position: absolute;
    bottom: -20px;
    right: -20px;
    background-color: var(--accent-brown);
    color: var(--white);
    padding: 20px 30px;
    font-family: 'Playfair Display', serif;
    font-size: 1.2rem;
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
}

.eco-features-list {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-top: 20px;
    border-top: 1px solid #eee;
    padding-top: 30px;
}

.eco-feature-item {
    display: flex;
    align-items: center;
    gap: 15px;
}

.eco-feature-item h4 {
    font-family: 'Lato', sans-serif;
    color: var(--primary-text);
    font-size: 1rem;
    margin-bottom: 3px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.eco-feature-item p {
    font-size: 0.85rem;
    color: #888;
    margin: 0;
}


/* --- STYLE: PRZEWODNIK PO SZYLIFACH (CUT GUIDE) --- */

.cut-guide-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 40px;
}

.cut-card {
    background: #fff;
    border: 1px solid var(--border-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    flex-direction: column;
}

.cut-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.08);
    border-color: var(--accent-gold);
}

.cut-image-wrapper {
    height: 250px;
    background-color: #fcfcfc;
    border-bottom: 1px solid #eee;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    overflow: hidden;
}

/* Formatowanie obrazków pobieranych z tagów */
.cut-image-wrapper img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain; /* Utrzymuje proporcje rysunków */
}

.cut-info {
    padding: 30px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.cut-info h3 {
    font-size: 1.5rem;
    color: var(--accent-brown);
    margin-bottom: 15px;
    border-bottom: 2px solid var(--bg-beige);
    padding-bottom: 10px;
}

.cut-info p {
    font-size: 0.95rem;
    color: #666;
    line-height: 1.6;
    margin-bottom: 20px;
}

/* Tabela Rozmiarów i Mas */
.size-table {
    width: 100%;
    border-collapse: collapse;
    margin-top: auto; /* Dopycha tabelę do dołu karty */
    font-size: 0.85rem;
}

.size-table th {
    text-align: left;
    text-transform: uppercase;
    color: var(--accent-brown);
    padding: 8px 0;
    border-bottom: 1px solid var(--accent-gold);
    font-weight: 700;
}

.size-table td {
    padding: 8px 0;
    color: #555;
    border-bottom: 1px dashed #eee;
}

.size-table tr:last-child td {
    border-bottom: none;
}

/* Wyróżnienie sekcji Moissanitów */
.premium-cut {
    background: var(--white);
    border: 1px solid #E8DECF;
}

.cut-highlights {
    list-style: none;
    padding: 0;
    margin-top: auto;
    background: #fafafa;
    padding: 15px;
    border-left: 2px solid var(--accent-gold);
}

.cut-highlights li {
    font-size: 0.85rem;
    color: #444;
    margin-bottom: 5px;
    display: flex;
    align-items: center;
}

.cut-highlights li::before {
    content: '✦';
    color: var(--accent-gold);
    margin-right: 8px;
    font-size: 0.8rem;
}

/* RWD */
@media (max-width: 768px) {
    .cut-guide-grid {
        grid-template-columns: 1fr; /* 1 kolumna na mobile */
    }
}


/* --- SEKCJA KONTAKTOWA --- */

.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr; /* Formularz zajmuje nieco więcej miejsca niż dane */
    gap: 60px;
    align-items: start;
    background-color: var(--bg-beige); /* Delikatne tło dla całej sekcji */
    padding: 60px;
    border: 1px solid var(--border-color);
}

.contact-info-block {
    padding-right: 20px;
}

.contact-link {
    color: var(--accent-brown);
    font-weight: 700;
    transition: color 0.3s ease;
    text-decoration: none;
}

.contact-link:hover {
    color: var(--accent-gold);
}

/* Luksusowy Formularz */
.luxury-form {
    background: #fff;
    padding: 40px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
}

.luxury-form .form-group {
    margin-bottom: 25px;
}

.luxury-form label {
    display: block;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #555;
    margin-bottom: 8px;
    font-weight: 700;
}

/* Minimalistyczne pola tekstowe - styl "Material / Luxury" */
.luxury-form input,
.luxury-form textarea {
    width: 100%;
    padding: 12px 0;
    background: transparent;
    border: none;
    border-bottom: 1px solid #ccc;
    font-family: 'Lato', sans-serif;
    font-size: 1rem;
    color: var(--primary-text);
    transition: border-color 0.3s ease;
    resize: vertical; /* Pozwala na powiększanie textarea tylko w pionie */
}

/* Usuwamy domyślny niebieski obrys przy kliknięciu (focus) i zmieniamy na złoty */
.luxury-form input:focus,
.luxury-form textarea:focus {
    outline: none;
    border-bottom: 2px solid var(--accent-gold);
}

.luxury-form input::placeholder,
.luxury-form textarea::placeholder {
    color: #bbb;
    font-weight: 300;
}


/* --- SEKCJA FAQ (HUB NAWIGACYJNY) --- */

.faq-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 kolumny na dużych ekranach */
    gap: 40px;
    align-items: start;
}

.faq-group {
    background-color: var(--white);
    border: 1px solid var(--border-color);
    box-shadow: 0 5px 20px rgba(0,0,0,0.03);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    height: 100%;
}

.faq-group:hover {
    transform: translateY(-5px);
    box-shadow: 0 15px 30px rgba(0,0,0,0.08);
    border-color: var(--accent-gold);
}

.faq-group-header {
    background-color: var(--bg-beige); /* Luksusowy, beżowy akcent w nagłówku */
    padding: 20px 25px;
    border-bottom: 1px solid var(--border-color);
}

.faq-group h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.4rem;
    color: var(--accent-brown);
    margin: 0;
}

.faq-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.faq-list li {
    border-bottom: 1px dashed #eee;
}

.faq-list li:last-child {
    border-bottom: none;
}

/* Stylizacja linków jako bloków (lepsze dla palca na mobile) */
.faq-list a {
    display: flex;
    justify-content: space-between; /* Rozsuwa tekst i strzałkę */
    align-items: center;
    padding: 15px 25px;
    font-size: 0.95rem;
    color: #555;
    text-decoration: none;
    transition: all 0.3s ease;
    line-height: 1.5;
}

.faq-list a .arrow {
    color: #ccc;
    font-size: 1.2rem;
    transition: transform 0.3s ease, color 0.3s ease;
}

/* Efekty najechania (Hover) */
.faq-list a:hover {
    color: var(--accent-brown);
    background-color: #fafafa;
    padding-left: 30px; /* Delikatne wcięcie przy najechaniu */
}

.faq-list a:hover .arrow {
    color: var(--accent-gold);
    transform: translateX(5px); /* Strzałka przesuwa się w prawo */
}

/* --- WERSJA MOBILNA --- */
@media (max-width: 992px) {
    .faq-grid {
        grid-template-columns: repeat(2, 1fr); /* 2 kolumny na tabletach */
        gap: 30px;
    }
}

@media (max-width: 768px) {
    .faq-grid {
        grid-template-columns: 1fr; /* 1 kolumna na telefonach */
        gap: 20px;
    }

    .faq-group-header {
        padding: 15px 20px;
    }

    .faq-list a {
        padding: 15px 20px; /* Odpowiednio duże pola dotykowe */
    }
    
    /* Wyłączamy wcięcie hover na telefonach, gdzie nie ma myszki */
    .faq-list a:hover {
        padding-left: 20px;
    }
}

/* CSS: Stylowanie kontenera i okładki */
    .video-container {
            /* 50px to margines na górze i na dole. 
               "auto" sprawia, że film jest wyśrodkowany na stronie. */
            margin: 0px auto; 
            text-align: center;
        }


/* --- OKRUSZKI (BREADCRUMBS) --- */
.breadcrumbs ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    font-size: 0.85rem;
    color: #888;
}

.breadcrumbs li a {
    color: #888;
    text-decoration: none;
    transition: color 0.3s;
}

.breadcrumbs li a:hover {
    color: var(--accent-brown);
    text-decoration: underline;
}

.breadcrumbs .separator {
    margin: 0 10px;
    color: #ccc;
}

/* --- POJEDYNCZY ARTYKUŁ FAQ --- */
.faq-content-wrapper {
    max-width: 800px; /* Ograniczamy szerokość dla komfortu czytania */
    margin: 0 auto;   /* Wyśrodkowanie na stronie */
}

.faq-title {
    font-size: 2.5rem;
    color: var(--accent-brown);
    font-family: 'Playfair Display', serif;
    margin-bottom: 30px;
    line-height: 1.2;
}

.faq-answer p {
    font-size: 1.05rem;
    color: #444;
    line-height: 1.8;
    margin-bottom: 20px;
}

.faq-answer ul {
    list-style: none;
    padding-left: 0;
    margin-bottom: 30px;
}

.faq-answer ul li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 15px;
    color: #444;
    line-height: 1.6;
}

.faq-answer ul li::before {
    content: '✦'; /* Złota gwiazdka zamiast standardowej kropki */
    position: absolute;
    left: 0;
    top: 0;
    color: var(--accent-gold);
    font-size: 1rem;
}

.faq-answer ul li strong {
    color: var(--accent-brown);
}

/* --- SEKCJA CTA W FAQ --- */
.faq-cta-box {
    margin-top: 60px;
    padding: 40px;
    background-color: var(--bg-beige);
    border: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
}

.faq-cta-buttons {
    display: flex;
    gap: 15px;
}

/* WERSJA MOBILNA */
@media (max-width: 768px) {
    .faq-title {
        font-size: 2rem;
    }

    .faq-answer p, 
    .faq-answer ul li {
        font-size: 1rem;
    }

    .faq-cta-box {
        flex-direction: column;
        text-align: center;
        padding: 30px 20px;
    }

    .faq-cta-buttons {
        flex-direction: column;
        width: 100%;
    }

    .faq-cta-buttons .btn-outline,
    .faq-cta-buttons .btn-primary {
        text-align: center;
        width: 100%;
    }
	
	section.container.section-padding {
                padding-left: 15px !important;
                padding-right: 15px !important;
            }
}


.social-icons-wrapper {
        margin-top: 25px;
        display: flex;
        justify-content: center; /* Zmień na 'flex-start', jeśli wolisz wyrównać ikony do lewej */
        gap: 20px;
    }
    
    .social-icon {
        color: #ffffff; /* Biały kolor ikon */
        width: 24px;
        height: 24px;
        display: inline-block;
        transition: opacity 0.3s ease, transform 0.3s ease;
    }
    
    .social-icon:hover {
        opacity: 0.7; /* Efekt przyciemnienia po najechaniu */
        transform: translateY(-2px); /* Delikatne uniesienie po najechaniu */
    }

/* ==========================================================================
   6. SEKCJE SPECYFICZNE (KAMIENIE & KOLEKCJE)
   ========================================================================== */
.collection-block { padding-bottom: 6.25rem; border-bottom: 1px solid #eee; }
.collection-block.bg-light { background-color: #fafafa; }
.col-banner {
    width: 100%; height: 15.625rem; background-size: cover; background-position: center; background-attachment: fixed;
    display: flex; align-items: center; justify-content: center; position: relative;
}
.col-banner::after { content: ''; position: absolute; inset: 0; background: rgba(0,0,0,0.3); }
.banner-title { position: relative; z-index: 2; color: #fff; font-size: 4rem; text-transform: uppercase; letter-spacing: 5px; text-shadow: 0 2px 10px rgba(0,0,0,0.3); }

.col-content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; padding-top: 6.25rem; margin-top: -3.75rem; }
.col-text h2 { font-size: 3rem; color: var(--accent-brown); margin-bottom: 1.25rem; line-height: 1.1; }
.col-text p { color: #666; font-size: 1.05rem; margin-bottom: 1.875rem; text-align: justify; }

.eco-features-list { display: flex; flex-direction: column; gap: 1.25rem; margin-top: 1.25rem; border-top: 1px solid #eee; padding-top: 1.875rem; }
.eco-feature-item { display: flex; align-items: center; gap: 0.9375rem; }
.eco-feature-item h4 { font-family: 'Lato', sans-serif; color: var(--primary-text); font-size: 1rem; text-transform: uppercase; letter-spacing: 1px; }

.col-img-wrapper { position: relative; z-index: 1; }
.col-img-wrapper img { width: 100%; height: 31.25rem; object-fit: cover; box-shadow: 0 20px 50px rgba(0,0,0,0.1); }
.col-floating-box {
    position: absolute; bottom: 30px; left: -40px; background: var(--box-bg); padding: 1.875rem 2.5rem;
    border: 1px solid var(--accent-gold); box-shadow: 0 10px 30px rgba(0,0,0,0.1); min-width: 15.625rem; z-index: 2;
}
.col-floating-box.left-pos { left: auto; right: -40px; }
.col-floating-box h4 { font-size: 1.5rem; color: var(--accent-brown); margin-bottom: 5px; }
.col-floating-box p { font-size: 0.9rem; color: #888; margin-bottom: 1.25rem; font-style: italic; }

/* Sklep - Kategorie */
.category-filter { padding: 1.25rem 0; border-bottom: 1px solid #eee; margin-bottom: 2.5rem; display: flex; gap: 0.9375rem; flex-wrap: wrap; }
.filter-item { cursor: pointer; text-transform: uppercase; font-size: 0.8rem; color: #888; font-weight: 700; }
.filter-item.active { color: var(--accent-brown); border-bottom: 2px solid var(--accent-brown); }
.product-minimal { position: relative; }
.product-minimal img { height: 15.625rem; width: 100%; margin-bottom: 0.9375rem; background: #f9f9f9; object-fit: cover; }
.price-tag-bar { background: #C4A484; color: white; text-align: center; padding: 8px; font-size: 0.8rem; letter-spacing: 1px; margin-bottom: 10px; }
.price-tag-bar.light { background: #E0E0E0; color: #555; }

/* ==========================================================================
   7. STOPKA I COOKIES
   ========================================================================== */
.site-footer { background: #222; color: #fff; padding: 3.75rem 0; margin-top: 5rem; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2.5rem; }
.footer-col h4 { margin-bottom: 1.25rem; color: var(--accent-gold); font-size: 1.2rem; }
.footer-col ul li { margin-bottom: 10px; }
.footer-col a { color: #ccc; transition: 0.3s; }
.footer-col a:hover { color: var(--accent-gold); }

#pola-cookie-banner {
    position: fixed; bottom: 0; left: 0; width: 100%; background-color: #f8f9fa; color: #333;
    padding: 1.25rem; box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1); display: flex; flex-direction: column;
    align-items: center; justify-content: center; z-index: 9999; text-align: center;
}
.pola-cookie-text { margin-bottom: 15px; max-width: 50rem; line-height: 1.5; }
.pola-cookie-text a { color: #0056b3; text-decoration: underline; font-weight: bold; }
.pola-cookie-buttons { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }
.pola-btn { padding: 10px 20px; border: none; border-radius: 4px; cursor: pointer; font-weight: bold; transition: 0.3s; }
.pola-btn-accept { background-color: #28a745; color: white; }
.pola-btn-accept:hover { background-color: #218838; }
.pola-btn-necessary { background-color: #e2e6ea; color: #333; border: 1px solid #dae0e5; }
.pola-btn-necessary:hover { background-color: #d3d9df; }

/* ==========================================================================
   8. MEDIA QUERIES (RESPONSYWNOŚĆ GLOBALNA)
   ========================================================================== */
@media (max-width: 900px) {
    .grid-3, .grid-4, .best-seller, .video-showcase-wrapper, .features-text-grid, .col-content-grid, .collections-frame-grid, .sale-square-section {
        grid-template-columns: 1fr;
        display: flex; flex-direction: column;
    }
    .best-seller-img, .best-seller-img2 { min-height: 25rem; width: 100%; }
    .best-seller-content { padding: 3rem 1.5rem; }
    .best-seller-content h2 { font-size: 2rem; }
    .video-showcase-wrapper { padding: 2rem 1rem; border-left: none; border-top: 3px solid var(--accent-gold); gap: 2rem; }
    
    .luxury-hero { justify-content: center; height: 37.5rem; }
    .info-card { margin: 0 1.25rem; padding: 2.5rem 1.25rem; }
    .main-title { font-size: 2.5rem; }
    
    .col-content-grid { padding-top: 3.125rem; gap: 2.5rem; }
    .col-content-grid.reverse-layout { flex-direction: column-reverse; }
    .col-img-wrapper { width: 90%; margin: 0 auto; }
    .col-img-wrapper img { height: 21.875rem; }
    .col-floating-box, .col-floating-box.left-pos {
        left: 50%; bottom: -30px; transform: translateX(-50%); right: auto; width: 80%; text-align: center;
    }
    .banner-title { font-size: 2.5rem; }
    
    .footer-grid { grid-template-columns: repeat(2, 1fr); }
    .sale-square-section { padding: 3.75rem 1.25rem; text-align: center; gap: 2.5rem; }
    .sale-square { width: 100%; max-width: 21.875rem; height: 18.75rem; font-size: 2rem; }
	
	 .contact-grid {
        grid-template-columns: 1fr; /* Kolumny układają się jedna pod drugą */
        padding: 30px 20px;
        gap: 40px;
    }
    
    .contact-info-block {
        padding-right: 0;
        text-align: center; /* Wyśrodkowanie danych na telefonie */
    }
    
    .luxury-form {
        padding: 30px 20px; /* Nieco mniejsze marginesy wewnętrzne formularza */
    }
}

@media (max-width: 600px) {
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .footer-col img, .footer-col button { margin: 0 auto; display: block; }
}