/*
 * ARCHIV ZÁHAD - Hlavní CSS soubor
 * Verze: Modernizovaná (UI Refresh + Footer)
 * (VERZE 2.0: Doplněny styly pro Gamifikaci 2.0)
 * (VERZE 2.3: Oprava výšky mobilního menu na 100vh)
 */

/* --- Proměnné --- */
:root {
    --bg-dark: #0F0F1A;
    --bg-light: #1A1A2B;
    --text-primary: #f5f5f5;
    --text-secondary: #b0b0b0;
    --border-color: rgba(255, 255, 255, 0.1); /* Lehce viditelnější */
    
    --accent: #A020F0;
    --accent-hover: #C040FF;
    --accent-secondary: #00BFFF;
    
    /* Barvy pro hodnosti */
    --rank-bronze: #cd7f32;
    --rank-silver: #c0c0c0;
    --rank-gold: #ffd700;

    /* Barvy pro statusy a reakce */
    --color-danger: #F44336;
    --color-success: #4CAF50;
    --color-warning: #FFC107;
    --color-info: #17a2b8;
    
    /* Nové globální proměnné */
    --border-radius-main: 10px;
    --transition-main: all 0.3s ease;
}

/* --- Základní nastavení --- */
body {
    font-family: 'Roboto', sans-serif;
    margin: 0;
    padding: 0;
    background: linear-gradient(180deg, var(--bg-light) 0%, var(--bg-dark) 25%);
    background-attachment: fixed;
    color: var(--text-primary);
    line-height: 1.7;
}

/* --- Hlavička a Navigace --- */
.header {
    background: rgba(15, 15, 26, 0.7);
    backdrop-filter: blur(14px) saturate(180%);
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    width: 100%;
    z-index: 1000;
}
.nav-container { max-width: 1500px; margin: 0 auto; padding: 0 30px; display: flex; justify-content: space-between; align-items: center; }

.logo {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.8rem;
    color: var(--text-primary);
    text-decoration: none;
}
.logo span { color: var(--accent); }

.main-nav { display: flex; align-items: center; }
.main-nav a, .main-nav .dropdown-toggle { color: var(--text-primary); text-decoration: none; padding: 22px 20px; display: inline-block; font-weight: 700; transition: var(--transition-main); position: relative; }
.main-nav a:hover, .main-nav a.active, .main-nav .dropdown-toggle:hover { color: var(--accent); background-color: rgba(255, 255, 255, 0.05); }
.dropdown { position: relative; }
.dropdown-menu { display: none; position: absolute; top: 100%; left: 0; background: var(--bg-light); border-radius: 0 0 var(--border-radius-main) var(--border-radius-main); border: 1px solid var(--border-color); box-shadow: 0 8px 15px rgba(0,0,0,0.3); min-width: 200px; padding: 10px 0; }
.dropdown-menu a { padding: 12px 20px; width: 100%; box-sizing: border-box; color: var(--text-secondary); }
.dropdown-menu a:hover { color: var(--accent); background-color: rgba(255, 255, 255, 0.05); }
.dropdown:hover .dropdown-menu { display: block; }
.user-nav { display: flex; align-items: center; }
.add-content-btn { 
    background-color: var(--accent); 
    color: #fff; 
    padding: 10px 20px; 
    border-radius: 50px; 
    text-decoration: none; 
    font-weight: 700; 
    margin-right: 20px; 
    transition: var(--transition-main); 
    box-shadow: 0 4px 15px rgba(160, 32, 240, 0.2);
}
.add-content-btn:hover { 
    background-color: var(--accent-hover); 
    transform: translateY(-2px); 
    box-shadow: 0 6px 20px rgba(160, 32, 240, 0.3);
}
.search-icon, .profile-icon { font-size: 1.7rem; color: var(--text-secondary); cursor: pointer; transition: color 0.3s; text-decoration: none; margin-left: 20px; }
.search-icon:hover, .profile-icon:hover { color: var(--text-primary); }

/* === NOVÉ STYLY: Mobilní menu (Hamburger) === */
.mobile-menu-toggle {
    display: none; /* Skryto na desktopu */
    background: none;
    border: none;
    color: var(--text-primary);
    font-size: 2rem;
    cursor: pointer;
    z-index: 1002; /* Nad hlavičkou, ale pod overlay */
}
.mobile-menu-toggle .sr-only { /* Pro přístupnost */
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

/* ======================================================
   ZDE JE KLÍČOVÁ OPRAVA (změna 100% na 100vh)
   ====================================================== */
.mobile-menu-overlay {
    display: none; /* Skryto na desktopu */
    position: fixed;
    top: 0; /* Začíná nahoře */
    left: 0;
    width: 100%;
    height: 100vh; /* <<<<< ZMĚNA: Používáme 100% výšky okna (vh) místo 100% */
    background: rgba(15, 15, 26, 0.98); /* Tmavší, méně průhledné */
    backdrop-filter: blur(10px);
    z-index: 1001; /* Pod toggle, ale nad vším ostatním */
    overflow-y: auto;
    padding: 100px 30px 30px 30px; /* Padding nahoře, aby bylo místo pro zavření */
    box-sizing: border-box;
    
    /* Animace */
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.mobile-menu-overlay.active {
    display: block;
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

/* Změna ikony hamburgeru na "X" když je menu otevřené */
body.mobile-menu-active .mobile-menu-toggle {
    position: fixed; /* Aby zůstal na místě při scrollu overlaye */
    top: 15px;
    right: 20px; /* Zarovnání s paddingem .nav-container */
    color: var(--text-primary);
}
body.mobile-menu-active .mobile-menu-toggle .fa-bars {
    display: none;
}
body.mobile-menu-active .mobile-menu-toggle .fa-times {
    display: block;
}
.mobile-menu-toggle .fa-times {
    display: none; /* Skryté "X" defaultně */
}

/* Zákaz scrollu na body, když je menu otevřené */
body.mobile-menu-active {
    overflow: hidden;
}

.mobile-main-nav {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    position: relative; /* Oprava z-index kontextu pro filtry */
    z-index: 10;        /* Oprava z-index kontextu pro filtry */
}
.mobile-main-nav a {
    color: var(--text-primary);
    text-decoration: none;
    font-size: 1.8rem;
    font-weight: 700;
    padding: 10px;
    transition: var(--transition-main);
}
.mobile-main-nav a:hover,
.mobile-main-nav a.active {
    color: var(--accent);
    transform: scale(1.1);
}

.mobile-main-nav .mobile-nav-divider {
    font-size: 1rem;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 20px;
    padding-bottom: 5px;
    border-bottom: 1px solid var(--border-color);
    width: 80%;
    text-align: center;
}

.mobile-main-nav .mobile-add-content-btn,
.mobile-main-nav .mobile-admin-btn {
    padding: 12px 25px;
    border-radius: 50px;
    font-size: 1.2rem;
    margin-top: 10px;
}

.mobile-main-nav .mobile-add-content-btn {
    background-color: var(--accent);
    color: #fff;
}
.mobile-main-nav .mobile-admin-btn {
    background-color: var(--rank-gold);
    color: var(--bg-dark);
}
/* === KONEC NOVÝCH STYLŮ PRO MOBILNÍ MENU === */


/* --- Banner "Žhavá stopa" --- */
.hot-news-banner {
    background: linear-gradient(90deg, var(--accent) 0%, var(--accent-hover) 100%);
    padding: 20px 30px;
    text-align: center;
    box-shadow: 0 5px 20px rgba(160, 32, 240, 0.3);
}
.hot-news-banner a { text-decoration: none; color: #fff; }
.hot-news-banner .hot-tag { font-size: 0.9em; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; opacity: 0.8; }
.hot-news-banner h2 { font-family: 'Montserrat', sans-serif; font-size: 1.9rem; margin: 5px 0 0 0; letter-spacing: -0.5px; }

/* --- Kontejner --- */
.container { max-width: 1500px; margin: 40px auto; padding: 0 30px; display: flex; gap: 40px; }
.main-content { flex: 3; }
.sidebar { flex: 1; }

.section-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.9rem;
    font-weight: 700;
    color: var(--text-primary);
    border-bottom: 3px solid var(--accent);
    padding-bottom: 10px;
    margin-bottom: 30px;
    letter-spacing: -0.5px;
}
.section-title.community { border-bottom-color: var(--accent-secondary); }

.card { 
    background-color: var(--bg-light); 
    border-radius: var(--border-radius-main); 
    margin-bottom: 40px; 
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15); 
    overflow: hidden; 
    transition: var(--transition-main); 
    border: 1px solid var(--border-color); 
    position: relative; /* Pro stretched-link */
}
.card:hover { 
    transform: translateY(-5px); 
    box-shadow: 0 8px 25px rgba(160, 32, 240, 0.2); 
    border-color: var(--accent);
}
.card-image { width: 100%; height: 220px; object-fit: cover; }

/* Hlavní téma */
.featured-story { 
    display: flex; 
    height: 350px; 
    position: relative; /* Pro stretched-link */
    transition: var(--transition-main); /* Pro hover */
}
.featured-image { flex: 2; background-size: cover; background-position: center center; }
.featured-content { flex: 3; padding: 35px; }

/* --- Vylepšený styl pro štítky kategorií --- */
/* TOTO NAHRAZUJE PŮVODNÍ .featured-content .category */
.category-link,
.featured-content .category {
    display: inline-block;
    padding: 6px 15px;
    margin-bottom: 10px;
    background-color: var(--accent);
    color: #fff;
    font-size: 0.85em;
    font-weight: 700;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 50px;
    letter-spacing: 0.5px;
    transition: var(--transition-main);
    z-index: 2; /* Musí být nad stretched-link pseudo-elementem */
    position: relative; /* Kvůli z-index */
}

.category-link:hover {
    background-color: var(--accent-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(160, 32, 240, 0.4);
}
/* --- Konec stylu štítků --- */

.featured-content h2 { font-family: 'Montserrat', sans-serif; font-size: 2.1rem; margin-top: 10px; letter-spacing: -1px; }
.featured-content h2 a { color: var(--text-primary); text-decoration: none; }
.featured-content p { color: var(--text-secondary); }

/* Sekce Podcast */
.latest-episode-section { background-color: var(--bg-light); border-radius: var(--border-radius-main); margin-bottom: 40px; border: 1px solid var(--border-color); display: flex; gap: 25px; padding: 25px; }
.episode-cover { width: 120px; height: 120px; border-radius: 8px; flex-shrink: 0; object-fit: cover; }
.episode-details { flex-grow: 1; }
.episode-details .episode-tag { font-weight: 700; color: var(--accent); text-transform: uppercase; font-size: 0.9em; }
.episode-details h2 { font-family: 'Montserrat', sans-serif; font-size: 1.9rem; margin: 5px 0 10px 0; color: var(--text-primary); letter-spacing: -0.5px; }
.episode-player { width: 100%; margin-top: 15px; }

/* Mřížka článků */
.article-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 30px; }
.grid-item .card-content { padding: 30px; }
.grid-item h3 { font-family: 'Montserrat', sans-serif; font-size: 1.4rem; margin-top: 0; line-height: 1.4; }
.grid-item h3 a { color: var(--text-primary); text-decoration: none; }
.grid-item .post-meta { font-size: 0.85em; color: var(--text-secondary); }

/* Mřížka hlášení */
.reports-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 25px; }
.report-card { 
    background-color: var(--bg-light); 
    border-radius: var(--border-radius-main); 
    border: 1px solid var(--border-color); 
    transition: var(--transition-main); 
    overflow: hidden; 
    position: relative; /* Pro stretched-link */
}
.report-card:hover { transform: translateY(-5px); box-shadow: 0 8px 20px rgba(0, 191, 255, 0.2); border-color: var(--accent-secondary); }
.report-card-content { padding: 20px; }
.report-card .tag { display: inline-block; background-color: var(--accent-secondary); color: var(--bg-dark); padding: 3px 10px; border-radius: 15px; font-size: 0.8em; font-weight: 700; margin-bottom: 10px; z-index: 2; position: relative; }
.report-card h4 { margin: 5px 0 10px 0; }
.report-card h4 a { color: var(--text-primary); text-decoration: none; }
.report-card .report-meta { font-size: 0.8em; color: var(--text-secondary); }
.report-meta a { color: var(--accent-secondary); text-decoration: none; }
.report-meta .user-rank { font-style: italic; }


/* --- NOVÉ: CTA Registrace na Home Page --- */
.register-cta {
    margin-top: 40px; 
    /* Využívá .widget pro pozadí a border */
    text-align: center;
}
.register-cta h3 {
    color: var(--accent); /* Zvýraznění fialovou */
    font-size: 1.5em;
    border-bottom: none; /* Přepsání .widget h3 */
    padding-bottom: 0;
    margin-bottom: 15px;
}
.register-cta h3 .fas {
     color: var(--accent);
     margin-right: 10px;
}
.register-cta p {
    font-size: 1.05em; 
    color: var(--text-secondary);
    line-height: 1.6;
    max-width: 700px; 
    margin: 20px auto 25px auto;
}
.register-cta .cta-button {
    display: inline-block;
    padding: 12px 30px;
    font-size: 1.1em;
    font-weight: 700;
    background-color: var(--accent);
    color: #fff; /* Přepsání .cta-widget .cta-button (který je bílý) */
    text-decoration: none;
    border-radius: 50px;
    transition: var(--transition-main);
}
.register-cta .cta-button:hover {
    background-color: var(--accent-hover);
    transform: scale(1.05);
    color: #fff;
}
/* --- KONEC NOVÝCH STYLŮ CTA --- */


/* Mřížka Galerie */
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.gallery-item a { display: block; text-decoration: none; }
.gallery-item img { width: 100%; height: 180px; object-fit: cover; border-radius: 8px; border: 1px solid var(--border-color); transition: var(--transition-main); }
.gallery-item img:hover { transform: scale(1.05); box-shadow: 0 8px 20px rgba(0, 191, 255, 0.2); }


/* ====================================================================
    NOVÉ STYLY PRO DOPORUČENÉ ČLÁNKY (PŘIDÁNO)
==================================================================== */
.recommended-articles .recommended-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* 3 sloupce */
    gap: 20px;
    margin-top: 20px;
}

.recommended-item {
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.recommended-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

.recommended-item .recommended-image-link {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9; /* Zajistí jednotný poměr stran */
    background-size: cover;
    background-position: center;
    border-bottom: 1px solid var(--border-color);
}

.recommended-item .recommended-content {
    padding: 15px;
}

/* Používá .category-link, takže není třeba redefinovat, ale pro jistotu menší úprava pro kontext */
.recommended-item .category-link {
    font-size: 0.8em;
    font-weight: 700;
    margin-bottom: 5px;
    display: inline-block;
    color: var(--text-secondary); /* Může být jiná než hlavní fialová */
    background: none; /* Bez pozadí */
    padding: 0;
    border-radius: 0;
}
.recommended-item .category-link:hover {
    background: none;
    transform: none;
    box-shadow: none;
    color: var(--accent); /* Zvýrazní se při hoveru */
}


.recommended-item .recommended-title {
    font-size: 1.1rem; 
    margin: 0;
    line-height: 1.3;
}

.recommended-item .recommended-title a {
    text-decoration: none;
    color: var(--text-primary);
}

.recommended-item .recommended-title a:hover {
    color: var(--accent);
}
/* ====================================================================
    KONEC NOVÝCH STYLŮ PRO DOPORUČENÉ ČLÁNKY
==================================================================== */


/* --- Klikatelné karty (Stretched Link) --- */
.stretched-link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1; /* Je pod obsahem (např. pod kategorií) */
}

/* Styl pro nadpisy, aby se chovaly normálně */
.card-content h3 a.stretched-link,
.featured-content h2 a.stretched-link,
.report-card-content h4 a.stretched-link,
.grid-item h3 a.stretched-link {
    color: inherit;
    text-decoration: none;
    z-index: 2; /* Musí být nad stretched-link pseudo-elementem */
    position: relative; /* Kvůli z-index */
}

/* Podtržení nadpisu při hoveru na kartu */
.card:hover h3 a.stretched-link,
.report-card:hover h4 a.stretched-link,
.featured-story:hover h2 a.stretched-link,
.grid-item:hover h3 a.stretched-link {
    text-decoration: underline;
}
/* --- Konec Stretched Link --- */


/* --- Sidebar --- */
.widget { background-color: var(--bg-light); padding: 25px; border-radius: var(--border-radius-main); margin-bottom: 30px; border: 1px solid var(--border-color); }
.widget h3 { font-family: 'Montserrat', sans-serif; color: var(--text-primary); border-bottom: 2px solid #333; padding-bottom: 10px; margin-top: 0; }
.widget h3 .fa-icon { color: var(--accent); margin-right: 10px; }
.cta-widget { background: linear-gradient(145deg, var(--accent), var(--accent-hover)); text-align: center; }
.cta-widget h3 { color: #fff; border: none; }
.cta-widget p { color: #f0f0f0; font-size: 0.95em; margin-bottom: 20px; }
.cta-widget .cta-button { display: inline-block; padding: 12px 25px; background-color: #fff; color: var(--bg-dark); text-decoration: none; font-weight: 700; border-radius: 50px; transition: transform 0.2s ease; }
.cta-widget .cta-button:hover { transform: scale(1.05); }

/* Widget Poslední komentáře */
.comments-widget ul { list-style: none; padding: 0; margin: 0; }
.comments-widget li { border-bottom: 1px dashed var(--border-color); padding-bottom: 12px; margin-bottom: 12px; }
.comments-widget li:last-child { border-bottom: none; margin-bottom: 0; }
.comments-widget .comment-author { font-weight: 700; color: var(--text-primary); }
.comments-widget .user-rank { font-size: 0.9em; font-style: italic; margin-left: 5px; }
.comments-widget .comment-excerpt { font-size: 0.9em; color: var(--text-secondary); }
.comments-widget .comment-link { font-size: 0.9em; color: var(--accent); text-decoration: none; font-weight: 700; }
.comments-widget .comment-link:hover { text-decoration: underline; }

/* Widget Top uživatelé */
.top-users-widget ul { list-style: none; padding: 0; margin: 0; }
.top-users-widget li { display: flex; align-items: center; margin-bottom: 15px; }
.top-users-widget li:last-child { margin-bottom: 0; }
.top-users-widget .user-avatar { width: 40px; height: 40px; border-radius: 50%; margin-right: 12px; }
.top-users-widget .user-info { flex-grow: 1; }
.top-users-widget .user-name { font-weight: 700; color: var(--text-primary); }
.top-users-widget .user-rank { font-size: 0.9em; font-style: italic; }
.top-users-widget .rank-1 { color: var(--rank-gold); }
.top-users-widget .rank-2 { color: var(--rank-silver); }
.top-users-widget .rank-3 { color: var(--rank-bronze); }

/* Anketa */
.poll-widget ul { list-style: none; padding: 0; margin: 0; }
.poll-widget li { margin-bottom: 12px; font-size: 0.95em; }
.poll-widget input[type="radio"] { margin-right: 10px; accent-color: var(--accent); }
.poll-widget .poll-button { display: block; width: 100%; padding: 10px; background-color: var(--accent); color: var(--bg-dark); border: none; border-radius: 5px; font-weight: 700; cursor: pointer; transition: background-color 0.3s; }
.poll-widget .poll-button:hover { background-color: var(--accent-hover); }

/* --- Patička --- */
.footer {
    text-align: center;
    padding: 40px 20px;
    background-color: var(--bg-light);
    color: var(--text-secondary);
    margin-top: 40px;
    border-top: 1px solid var(--border-color);
}
.footer-logo { font-family: 'Montserrat', sans-serif; font-size: 1.5rem; color: var(--text-primary); margin-bottom: 10px; }
.footer-logo span { color: var(--accent); }
.footer p { margin: 5px 0; }

/* --- NOVÉ: Styly pro modernizovanou patičku --- */
@keyframes footer-glow {
    0% { opacity: 0; transform: translateY(10px); }
    100% { opacity: 1; transform: translateY(0); }
}
.footer-signature {
    font-size: 0.95em;
    color: var(--text-secondary);
    display: inline-block; /* Pro animaci */
    animation: footer-glow 1s ease-out 0.5s forwards;
    opacity: 0; /* Počáteční stav pro animaci */
}
.footer-signature .power-icon {
    display: inline-block;
    color: var(--rank-gold); /* Zlatá barva pro ikonu */
    margin-right: 5px;
    transition: var(--transition-main);
    transform-origin: center;
}
.footer-signature:hover .power-icon {
    transform: scale(1.3) rotate(15deg);
    text-shadow: 0 0 10px var(--rank-gold);
}
.footer-signature strong {
    color: var(--text-primary);
    font-weight: 700;
}
/* --- Konec stylů patičky --- */


/* --- Responzivita (Základní) --- */
@media (max-width: 1200px) {
    .container { flex-direction: column; }
    .main-content { width: 100%; }
    .sidebar { width: 100%; }
    .featured-story { flex-direction: column; height: auto; }
    .article-grid { grid-template-columns: 1fr; }
    .reports-grid { grid-template-columns: repeat(2, 1fr); }
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
    
    /* === PŘIDÁNO PRO DOPORUČENÉ ČLÁNKY === */
    .recommended-articles .recommended-grid {
        grid-template-columns: 1fr 1fr; /* 2 sloupce na tabletech */
    }
}
/* --- UPRAVENÁ RESPONZIVITA PRO MOBILY --- */
@media (max-width: 768px) {
    /* Skryjeme desktopovou navigaci */
    .main-nav { display: none; } 
    .user-nav .add-content-btn { display: none; } /* Skryjeme desktopové "Přidat obsah" */
    .user-nav .profile-icon { display: none; } /* Skryjeme desktop profil, je v mobilním menu */
    
    /* Zobrazíme hamburger */
    .mobile-menu-toggle { display: block; }
    
    /* Změníme layout hlavičky pro mobil */
    .nav-container { padding: 0 20px; height: 70px; } /* Sjednotit výšku */
    .logo { font-size: 1.5rem; }
    .user-nav { /* Necháme jen search icon */
        margin-left: auto; /* Posune se od loga */
    }
    .search-icon { margin-left: 15px; }
    
    /* Zbytek responzivních stylů */
    .reports-grid { grid-template-columns: 1fr; }
    .gallery-grid { grid-template-columns: 1fr; }
    .latest-episode-section { flex-direction: column; text-align: center; }
    .hot-news-banner h2 { font-size: 1.4rem; }

    /* === PŘIDÁNO PRO DOPORUČENÉ ČLÁNKY === */
    .recommended-articles .recommended-grid {
        grid-template-columns: 1fr; /* 1 sloupec na mobilu */
    }
}


/* --- Fáze 6 - Překryvné vyhledávání --- */
.search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 15, 26, 0.85);
    backdrop-filter: blur(14px) saturate(180%);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.search-overlay.active {
    opacity: 1;
    visibility: visible;
}
.search-overlay-close {
    position: absolute;
    top: 30px;
    right: 40px;
    font-size: 2.5rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: color 0.3s;
}
.search-overlay-close:hover {
    color: var(--text-primary);
}
.search-overlay-content {
    width: 90%;
    max-width: 700px;
}
.search-overlay-content h2 {
    font-family: 'Montserrat', sans-serif;
    font-size: 2rem;
    color: var(--text-secondary);
    text-align: center;
    margin-bottom: 25px;
}
.search-overlay-form {
    display: flex;
}
.search-overlay-input {
    flex-grow: 1;
    padding: 20px 25px;
    font-size: 1.5rem;
    background: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: 50px 0 0 50px;
    color: var(--text-primary);
    outline: none;
    transition: var(--transition-main);
}
.search-overlay-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 4px rgba(160, 32, 240, 0.3); /* Moderní focus ring */
}
.search-overlay-submit {
    padding: 0 30px;
    font-size: 1.5rem;
    border: none;
    background: var(--accent);
    color: #fff;
    cursor: pointer;
    border-radius: 0 50px 50px 0;
    transition: background-color 0.3s;
}
.search-overlay-submit:hover {
    background: var(--accent-hover);
}


/* --- Fáze 6 - Lightbox --- */
.lightbox {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(15, 15, 26, 0.9);
    backdrop-filter: blur(10px);
    z-index: 3000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}
.lightbox.active {
    opacity: 1;
    visibility: visible;
}
.lightbox-close {
    position: absolute;
    top: 20px;
    right: 30px;
    font-size: 2.5rem;
    color: var(--text-secondary);
    cursor: pointer;
    transition: color 0.3s;
    z-index: 3002;
}
.lightbox-close:hover {
    color: var(--text-primary);
}
.lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 3rem;
    color: var(--text-secondary);
    cursor: pointer;
    z-index: 3002;
    padding: 20px;
    user-select: none;
}
.lightbox-nav:hover {
    color: var(--text-primary);
}
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }

.lightbox-content {
    position: relative;
    max-width: 90vw;
    max-height: 85vh;
}

/* === TOTO BYLO UPRAVENO (1/2) === */
.lightbox-content img {
    max-width: 100%;
    max-height: 85vh;
    object-fit: contain;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    display: block; /* <-- PŘIDÁNO: Zajišťuje správné blokové chování */
}

/* === TOTO BYLO UPRAVENO (2/2) === */
.lightbox-caption {
    position: absolute; /* <-- ZMĚNA: Popisek je vyjmut z toku */
    bottom: 0;          /* <-- ZMĚNA: Umístění na spodek kontejneru */
    left: 0;            /* <-- ZMĚNA: Umístění zleva */
    width: 100%;        /* <-- ZMĚNA: Plná šířka kontejneru */
    
    /* Vylepšení vzhledu pro překrytí */
    background: rgba(15, 15, 26, 0.75); /* Poloprůhledné pozadí */
    backdrop-filter: blur(5px);         /* Efekt rozmazání podkladu */
    padding: 20px;
    box-sizing: border-box; /* Aby padding neovlivnil 100% šířku */
    border-radius: 0 0 8px 8px; /* Zaoblení spodních rohů (jako má obrázek) */
    
    /* Původní styly (upraveny) */
    text-align: center;
    color: var(--text-primary); /* Změna na lépe čitelnou primární barvu */
    font-size: 1.1rem;
    font-style: italic;
    /* margin-top: 15px; byl odstraněn */
}


/* ====================================================================
    STYLY PRO KOMENTÁŘE A AKCE (SJEDNOCENO S KNIHOU NÁVŠTĚV)
====================================================================
*/

.comments-section { 
    margin-top: 50px; 
}
.comment-list { 
    list-style: none; 
    padding: 0; 
    margin: 0; 
}

/* === VZHLED KOMENTÁŘE (Sjednoceno s Knihou návštěv) === */
.comment {
    display: flex;
    gap: 15px;
    padding: 20px;
    border-radius: 8px; /* Změna z 10px na 8px */
    margin-bottom: 20px;
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Změna stínu */
    /* Odstraněna transition a :hover efekt pro sjednocení */
}

.comment-avatar {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    flex-shrink: 0;
    object-fit: cover; /* Důležité pro ořezání */
}
.comment-body { 
    flex-grow: 1; 
}
.comment-author { 
    font-weight: 700; 
    color: var(--text-primary); 
}
.comment-meta { 
    font-size: 0.85em; 
    color: var(--text-secondary); 
    margin-bottom: 10px; 
}
.comment-content { 
    color: var(--text-secondary); 
}
.comment-form textarea {
    width: 100%; 
    min-height: 120px; 
    padding: 18px; /* Zvětšený padding */
    background-color: var(--bg-dark);
    border: 1px solid var(--border-color); 
    border-radius: var(--border-radius-main); 
    color: var(--text-primary);
    font-size: 1rem; 
    box-sizing: border-box; 
    margin-bottom: 15px;
    transition: var(--transition-main);
}
.comment-form textarea:focus { 
    outline: none; 
    border-color: var(--accent); 
    box-shadow: 0 0 0 4px rgba(160, 32, 240, 0.3); /* Moderní focus ring */
}
.comment-author .user-rank { 
    font-size: 0.9em; 
    font-style: italic; 
    margin-left: 6px; /* Změna z 5px na 6px */
}

/* === ZVÝRAZNĚNÍ ADMINŮ / EDITORŮ (Sjednoceno s Knihou návštěv) === */
.comment-admin { 
    background-color: rgba(160, 32, 240, 0.1); 
    border-color: var(--accent); 
    /* Odstraněn border-left */
}
/* Odstraněn :hover efekt */
.comment-admin .comment-author { 
    color: var(--accent); 
}

.comment-editor { 
    background-color: rgba(0, 191, 255, 0.1); 
    border-color: var(--accent-secondary); 
    /* Odstraněn border-left */
}
/* Odstraněn :hover efekt */
.comment-editor .comment-author { 
    color: var(--accent-secondary); 
}

/* === NOVÝ STYL: Ikona ? pro adminy === */
.comment-author .admin-power-icon,
.entry-author .admin-power-icon { /* Přidáno i pro .entry-author z guestbook_v2 */
    color: var(--rank-gold);
    font-size: 0.9em;
    display: inline-block;
    margin-left: 4px;
    text-shadow: 0 0 8px var(--rank-gold);
    transition: var(--transition-main);
    user-select: none; /* Aby nešla ikona označit myší */
}
.comment:hover .comment-author .admin-power-icon,
.entry:hover .entry-author .admin-power-icon {
    transform: scale(1.3) rotate(10deg);
}


/* --- Styly pro reakce a akce (Fáze 6.5) --- */

.comment-actions, .guestbook-actions {
    display: flex;
    gap: 15px;
    margin-top: 10px;
    align-items: center;
    font-size: 0.9em;
}

.reaction-btn {
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border: 1px solid var(--border-color);
    border-radius: 20px;
    background-color: transparent;
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.2s;
    z-index: 2; /* Musí být nad stretched-link pseudo-elementem */
    position: relative; /* Kvůli z-index */
}

.reaction-btn i {
    margin-right: 5px;
    font-size: 1.1em;
}

/* Aktivní (uživatelem zvolená) reakce */
.reaction-btn.active-like {
    border-color: var(--accent-secondary);
    background-color: rgba(0, 191, 255, 0.1);
    color: var(--accent-secondary);
}
.reaction-btn.active-dislike {
    border-color: var(--color-danger);
    background-color: rgba(244, 67, 54, 0.1);
    color: var(--color-danger);
}

.reaction-btn:hover:not(.active-like):not(.active-dislike) {
    background-color: rgba(255, 255, 255, 0.05);
}

/* === VYLEPŠENÉ: Tlačítko odpovědi === */
.reply-btn {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border: 1px solid var(--border-color);
    border-radius: 20px;
    background-color: transparent;
    color: var(--text-secondary); /* Změna z --accent */
    cursor: pointer;
    transition: all 0.2s;
    z-index: 2;
    position: relative;
    font-weight: 700;
    font-size: 1em; /* Sjednocení */
    text-decoration: none;
}

.reply-btn i {
    margin-right: 6px;
    font-size: 1.1em;
}

.reply-btn:hover {
    background-color: var(--accent);
    border-color: var(--accent);
    color: #fff; /* Bílá na fialovém pozadí */
}

/* === NOVÝ STYL: Tlačítko smazat (Moderace) === */
.moderate-btn {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border: 1px solid var(--border-color);
    border-radius: 20px;
    background-color: transparent;
    color: var(--color-danger); /* Červená */
    cursor: pointer;
    transition: all 0.2s;
    z-index: 2;
    position: relative;
    font-weight: 700;
    font-size: 1em;
    text-decoration: none;
}

.moderate-btn i {
     margin-right: 6px;
     font-size: 1.1em;
}

.moderate-btn:hover {
    background-color: var(--color-danger);
    border-color: var(--color-danger);
    color: #fff; /* Bílá na červeném pozadí */
    box-shadow: 0 0 10px rgba(244, 67, 54, 0.4);
}


/* Styly pro formuláře odpovědi */
.comment-list .comment-reply-form {
    margin-top: 15px;
    border-top: 1px dashed var(--border-color);
    padding-top: 15px;
}

/* Styly pro vnořené komentáře (vlákna) */
.comment-list .replies {
    list-style: none;
    padding-left: 20px; /* Odsazení pro odpovědi */
    margin-top: 20px;
}
.comment-list .replies .comment {
    background-color: var(--bg-dark); /* Odlišná barva pozadí */
    border-left: 3px solid var(--accent-secondary);
    padding: 15px;
    /* Zde ponecháváme původní styly vnořených komentářů, 
       protože Knihy návštěv vnořené komentáře nemá */
}


/* ====================================================================
    STYLY PRO INSPIRACI (PŘESUNUTO Z PHP)
====================================================================
*/

/* Styly pro vzhled "Knihovny / Filmotéky" (2:3 obaly) */
.inspiration-controls {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    background-color: var(--bg-light);
    padding: 15px 20px;
    border-radius: var(--border-radius-main);
    border: 1px solid var(--border-color);
}

.inspiration-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); 
    gap: 30px;
    margin-top: 30px;
}
.inspiration-card {
    background-color: var(--bg-light);
    border-radius: 12px;
    overflow: hidden;
    border: 1px solid var(--border-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    position: relative; 
    text-decoration: none; 
    color: var(--text-primary);
    display: block; 
}
.inspiration-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 25px rgba(160, 32, 240, 0.2); 
    border-color: var(--accent);
}
.inspiration-cover-wrapper {
    position: relative;
    padding-bottom: 150%; /* Poměr stran 2:3 pro "obal knihy/filmu" */
    height: 0;
    overflow: hidden;
    background-color: var(--bg-dark); 
}
.inspiration-cover {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover; 
}
.inspiration-content {
    padding: 20px;
}
.inspiration-tag {
    display: inline-block;
    background-color: var(--accent);
    color: white;
    padding: 4px 8px;
    border-radius: 4px;
    font-size: 0.8em;
    font-weight: 700;
    margin-bottom: 10px;
}
.inspiration-card h3 {
    font-family: 'Montserrat', sans-serif;
    font-size: 1.2rem; 
    margin-top: 0;
    margin-bottom: 5px;
    line-height: 1.3;
}
.inspiration-meta {
    font-size: 0.8em;
    color: var(--text-secondary);
    margin-bottom: 15px;
}
.inspiration-featured {
    border: 2px solid var(--rank-gold);
}
.inspiration-featured:hover {
    box-shadow: 0 10px 25px rgba(255, 215, 0, 0.3);
}

.inspiration-description {
    font-size: 0.9em;
    color: var(--text-secondary);
}


/* ====================================================================
    STYLY PRO DETAIL INSPIRACE (PŘESUNUTO Z PHP)
====================================================================
*/

.inspiration-detail-header {
    display: flex;
    gap: 30px;
    background-color: var(--bg-light);
    padding: 30px;
    border-radius: var(--border-radius-main);
    border: 1px solid var(--border-color);
    margin-bottom: 40px;
}
.detail-cover-area {
    flex-shrink: 0;
    width: 300px;
}
.detail-cover {
    width: 100%;
    height: 450px; /* Přísný poměr 2:3 */
    object-fit: cover;
    border-radius: 8px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.3);
    border: 1px solid var(--border-color);
}
.detail-info-area {
    flex-grow: 1;
}
.detail-tag {
    display: inline-block;
    font-size: 0.9em;
    font-weight: 700;
    padding: 6px 15px;
    border-radius: 50px;
    margin-bottom: 15px;
    background-color: var(--accent);
    color: white;
}
.detail-info-area h1 {
    font-family: 'Montserrat', sans-serif;
    font-size: 2.5rem;
    margin-top: 0;
    margin-bottom: 10px;
    letter-spacing: -1px;
}
.detail-meta {
    font-size: 1.1em;
    color: var(--text-secondary);
    margin-bottom: 25px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 15px;
}
.detail-meta strong {
    color: var(--text-primary);
}
.detail-description-box {
    background-color: var(--bg-dark);
    padding: 20px;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    margin-top: 20px;
}
.detail-description-box h3 {
    color: var(--accent);
    margin-top: 0;
}
.detail-description-box p {
    white-space: pre-wrap; /* Zachová formátování z textarea */
}

.detail-action-link {
    display: inline-block;
    padding: 12px 25px;
    background-color: var(--accent-secondary);
    color: var(--bg-dark);
    text-decoration: none;
    border-radius: 50px;
    font-weight: 700;
    margin-top: 20px;
    transition: transform 0.2s ease, box-shadow 0.3s ease;
}
.detail-action-link:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0, 191, 255, 0.4);
}
.featured-icon {
    color: var(--rank-gold); 
    margin-left: 10px; 
    font-size: 1.2em;
}

@media (max-width: 900px) {
    .inspiration-detail-header {
        flex-direction: column;
        text-align: center;
    }
    .detail-cover-area {
        width: 100%;
        max-width: 300px; 
        margin: 0 auto;
    }
    .detail-cover {
         height: 450px; 
    }
    .detail-meta, .detail-description-box {
        text-align: left;
    }
}


/* ====================================================================
    NOVÉ STYLY (Vyhledávání, Stránkování, Home)
====================================================================
*/

/* --- Nové styly pro inspiration.php controls --- */
.inspiration-controls form {
    display: flex;
    flex-wrap: wrap; /* Pro responzivitu */
    gap: 20px;
    align-items: center;
    width: 100%;
}

.filter-group {
    display: flex;
    align-items: center;
}

.filter-group label {
    color: var(--text-secondary);
    margin-right: 10px;
    font-size: 0.9em;
}

.inspiration-controls select,
.inspiration-controls input[type="search"] {
    padding: 8px 12px;
    background-color: var(--bg-dark);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
    border-radius: 6px;
    font-size: 1em;
}

.inspiration-controls input[type="search"] {
    min-width: 200px;
}
.inspiration-controls input[type="search"]:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 4px rgba(160, 32, 240, 0.3);
}

.inspiration-controls select {
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b0b0b0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 10px top 50%;
    background-size: 16px auto;
    padding-right: 35px;
}

.filter-submit-btn {
    padding: 9px 20px;
    background-color: var(--accent);
    color: #fff;
    border: none;
    border-radius: 6px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transition-main);
    margin-left: auto; /* Posune tlačítko doprava */
}
.filter-submit-btn:hover {
    background-color: var(--accent-hover);
}

@media (max-width: 768px) {
    .inspiration-controls form {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }
    .filter-group {
        justify-content: space-between;
    }
    .inspiration-controls input[type="search"] {
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
    .filter-submit-btn {
        margin-left: 0;
        text-align: center;
    }
}


/* --- Styly pro stránkování --- */
.pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 40px;
    padding: 15px 20px;
    background-color: var(--bg-light);
    border: 1px solid var(--border-color);
    border-radius: var(--border-radius-main);
}
.page-link {
    padding: 10px 20px;
    background-color: var(--accent);
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    border-radius: 50px;
    transition: var(--transition-main);
}
.page-link:hover {
    background-color: var(--accent-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(160, 32, 240, 0.3);
}
.page-current {
    font-size: 1.1em;
    color: var(--text-secondary);
    font-weight: 700;
}
@media (max-width: 480px) {
    .page-current {
        font-size: 0.9em;
    }
    .page-link {
        padding: 8px 15px;
        font-size: 0.9em;
    }
}

/* --- Styly pro inspiraci na Home Page --- */
.inspiration-grid-home {
    display: grid;
    grid-template-columns: repeat(4, 1fr); /* 4 sloupce */
    gap: 25px;
}

/* .inspiration-card-home využívá styly .inspiration-card */
.inspiration-card-home {
    text-decoration: none;
    color: var(--text-primary);
}

.inspiration-content-home {
    padding: 15px; /* Menší padding */
}

.inspiration-tag-home {
    display: inline-block;
    background-color: var(--accent);
    color: white;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 0.7em; /* Menší */
    font-weight: 700;
    margin-bottom: 8px;
    z-index: 2; /* Pro stretched-link */
    position: relative; /* Pro stretched-link */
}

.inspiration-card-home h3 {
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem; /* Menší */
    margin: 0;
    line-height: 1.3;
}

/* Responzivita pro .inspiration-grid-home */
@media (max-width: 1200px) {
    .inspiration-grid-home {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .inspiration-grid-home {
        grid-template-columns: repeat(2, 1fr); /* Na mobilu 2 vedle sebe */
    }
    .inspiration-grid {
        /* Hlavní mřížka inspirace na mobilu */
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
        gap: 20px;
    }
    .inspiration-card h3 {
        font-size: 1rem;
    }
}

/* === NOVÉ STYLY (DOPLNĚNO): Cookie Consent Banner === */
.cookie-consent-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: var(--bg-dark);
    border-top: 1px solid var(--border-color);
    padding: 20px 30px; /* Zarovnání s .nav-container */
    z-index: 4000;
    display: none; /* Skryto defaultně, JS zobrazí */
    box-shadow: 0 -5px 20px rgba(0,0,0,0.3);
    box-sizing: border-box;
}
.cookie-consent-content {
    max-width: 1500px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 20px;
}
.cookie-consent-text {
    color: var(--text-secondary);
    font-size: 0.9em;
    line-height: 1.6;
}
.cookie-consent-text a {
    color: var(--text-primary); /* Světlejší pro odkaz */
    text-decoration: underline;
    font-weight: 700;
    transition: color 0.3s;
}
.cookie-consent-text a:hover {
    color: var(--accent);
}
.cookie-consent-button {
    padding: 10px 20px;
    background-color: var(--accent);
    color: #fff;
    border: none;
    border-radius: 50px;
    font-weight: 700;
    cursor: pointer;
    transition: var(--transition-main);
    flex-shrink: 0; /* Zabrání zmenšení tlačítka */
}
.cookie-consent-button:hover {
    background-color: var(--accent-hover);
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(160, 32, 240, 0.3);
}

@media (max-width: 768px) {
    .cookie-consent-content {
        flex-direction: column;
        text-align: center;
    }
    .cookie-consent-button {
        width: 100%;
        margin-top: 10px;
    }
}
/* === KONEC NOVÝCH STYLŮ === */


/* ====================================================================
    NOVÉ STYLY (DOPLNĚNO): Gamifikace 2.0 (Notifikace a Profil)
====================================================================
*/

/* --- 1. Notifikace o nové hodnosti (Toast) --- */
@keyframes rank-up-slide-in {
    from {
        transform: translateY(-100px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}
@keyframes rank-up-fade-out {
    from {
        opacity: 1;
    }
    to {
        opacity: 0;
        transform: translateY(-20px);
    }
}

.rank-up-notification {
    position: fixed;
    top: 80px; /* Pod hlavičkou */
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(135deg, var(--rank-gold), #ffec80);
    color: var(--bg-dark);
    padding: 20px 30px;
    border-radius: var(--border-radius-main);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
    z-index: 9999;
    font-size: 1.2em;
    font-weight: 700;
    border: 2px solid #fff;
    animation: rank-up-slide-in 0.5s ease-out forwards;
}
.rank-up-notification i {
    margin-right: 15px;
    text-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.rank-up-notification.hide {
    animation: rank-up-fade-out 0.5s ease-in forwards;
}

/* --- 2. Styly pro profile.php --- */

/* Kontejner pro profilovou kartu (z profilu) */
.profile-info-grid {
    display: flex;
    align-items: center;
    gap: 25px;
    margin-bottom: 25px;
}
.profile-avatar {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--border-color);
}
.profile-details { flex-grow: 1; }
.profile-details h3 {
    margin: 0 0 5px 0;
    font-family: 'Montserrat', sans-serif;
    font-size: 1.8rem;
}
.profile-details .rank {
    font-size: 1.2rem;
    font-style: italic;
}

/* Flash zprávy na profilu (z profilu) */
.flash-message.card {
    padding: 15px 25px;
    margin-bottom: 20px;
    border-radius: 8px;
    border: 1px solid;
}
.flash-message.error {
    background-color: rgba(255, 0, 0, 0.1);
    border-color: red;
    color: #ffcccc;
}
.flash-message.success {
     background-color: rgba(0, 191, 255, 0.1);
     border-color: var(--accent-secondary);
     color: var(--accent-secondary);
}
 .flash-message.warning {
     background-color: rgba(255, 215, 0, 0.1);
     border-color: var(--rank-gold);
     color: var(--rank-gold);
 }

/* Formulářové prvky na profilu (z profilu) */
.profile-form .form-group { margin-bottom: 20px; }
.profile-form .form-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 700;
    color: var(--text-secondary);
}
.profile-form .form-group input[type="text"],
.profile-form .form-group input[type="email"],
.profile-form .form-group input[type="password"],
.profile-form .form-group input[type="file"] {
    width: 100%;
    padding: 12px 15px;
    background-color: var(--bg-dark);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    color: var(--text-primary);
    font-size: 1rem;
    box-sizing: border-box;
}
.profile-form .form-group input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 10px rgba(160, 32, 240, 0.3);
}
.profile-form .submit-btn {
    display: inline-block;
    padding: 12px 30px;
    background-color: var(--accent);
    color: #fff;
    text-decoration: none;
    font-weight: 700;
    border-radius: 50px;
    transition: background-color 0.3s;
    border: none;
    cursor: pointer;
    font-size: 1rem;
}
.profile-form .submit-btn:hover { background-color: var(--accent-hover); }

/* Widget postupu hodností (z profilu) */
.rank-progress-widget {
    margin-top: -15px; /* Přisuneme blíže k profilu */
    margin-bottom: 30px;
}
.rank-progress-text {
    display: flex;
    justify-content: space-between;
    font-size: 0.9em;
    color: var(--text-secondary);
    margin-bottom: 8px;
    font-weight: 700;
}
.rank-progress-text .next-rank {
    color: var(--text-primary);
}
.progress-bar-container {
    width: 100%;
    height: 12px;
    background-color: var(--bg-dark);
    border-radius: 6px;
    overflow: hidden;
    border: 1px solid var(--border-color);
}
.progress-bar {
    height: 100%;
    background: linear-gradient(90deg, var(--accent-secondary), var(--accent));
    border-radius: 6px;
    transition: width 0.5s ease;
}
.max-rank-message {
    text-align: center;
    font-weight: 700;
    color: var(--rank-gold);
    font-size: 1.1em;
}

/* Mřížka aktivit na profilu (z profilu) */
.profile-activity-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
}
/* Na menších obrazovkách pod sebou */
@media (max-width: 900px) {
    .profile-activity-grid {
        grid-template-columns: 1fr;
    }
}

/* Seznam aktivit (sdílený styl z profilu) */
.activity-list { 
    list-style: none; 
    padding: 0; 
    margin: 0; 
}
.activity-list li {
    border-bottom: 1px dashed var(--border-color);
    padding: 10px 0;
    display: flex;
    justify-content: space-between;
}
.activity-list li:last-child { border-bottom: none; }

/* Log historie bodů (z profilu) */
.activity-log { list-style: none; padding: 0; margin: 0; }
.activity-log li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 0;
    border-bottom: 1px dashed var(--border-color);
}
.activity-log li:last-child { border-bottom: none; }
.log-reason {
    color: var(--text-secondary);
}
.log-date {
    font-size: 0.8em;
    color: var(--text-secondary);
    opacity: 0.7;
}
.log-points {
    font-weight: 700;
    font-size: 1.1em;
    white-space: nowrap;
    padding-left: 15px;
}
.log-points.positive {
    color: var(--color-success);
}
.log-points.negative {
    color: var(--color-danger);
}
/* --- KONEC STYLŮ PRO GAMIFIKACI --- */

/* ====================================================================
    NOVÉ STYLY: Fáze 3 (Komunitní status a Mapa)
====================================================================
*/

/* Hlavní kontejner pro novou sekci */
.community-feedback {
    margin-top: -20px; /* Přisunutí blíže k článku */
    border-top: 1px solid var(--border-color);
}
.community-feedback:hover {
    transform: none; /* Deaktivujeme hover efekt pro tuto kartu */
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15); 
    border-color: var(--border-color);
}
.community-feedback .feedback-grid {
    display: grid;
    grid-template-columns: 2fr 1fr; /* 2/3 pro status, 1/3 pro mapu */
    gap: 40px;
}

/* Část 1: Stav případu */
.status-poll { 
    display: flex; 
    flex-direction: column; 
    gap: 12px; /* Zvětšená mezera */
    margin-bottom: 20px; 
}
.status-option { 
    display: grid; 
    grid-template-columns: 120px 1fr 100px; /* Sloupce: Popisek | Graf | Procenta */
    gap: 10px; 
    align-items: center; 
    font-size: 0.9em; 
    padding: 5px;
    border-radius: 5px;
    transition: background-color 0.3s;
}
.status-label { 
    font-weight: 700; 
    color: var(--text-primary); 
    font-size: 1.1em; /* Zvětšení popisku */
}
.status-votes { 
    font-size: 0.9em; 
    color: var(--text-secondary); 
    text-align: right; 
    font-weight: 700;
}
.status-bar-container { 
    width: 100%; 
    height: 12px; /* Zvětšení grafu */
    background-color: var(--bg-dark); 
    border-radius: 6px; 
    overflow: hidden; 
}
.status-bar { 
    height: 100%; 
    background-color: var(--accent); 
    border-radius: 6px; 
    transition: width 0.5s ease; 
}
.status-bar.plausible { 
    background-color: #3498db; /* Modrá */
}
.status-bar.hoax { 
    background-color: #e74c3c; /* Červená */
}

/* Zvýraznění volby, kterou uživatel provedl */
.status-option.user-voted {
    background-color: rgba(255, 255, 255, 0.05);
}
.status-option.user-voted .status-label,
.status-option.user-voted .status-votes {
    color: var(--accent-secondary);
}

/* Formulář pro hlasování */
.status-vote-form select.form-control {
    width: 100%;
    padding: 12px 15px;
    background-color: var(--bg-dark);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    color: var(--text-primary);
    font-size: 1rem;
    font-weight: 700;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b0b0b0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 15px top 50%;
    background-size: 16px auto;
}
.status-vote-form select:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 4px rgba(160, 32, 240, 0.3);
}


/* Část 2: Propojení s mapou */
.map-link { 
    border-left: 2px solid var(--border-color); 
    padding-left: 40px; 
    display: flex;
    flex-direction: column;
    justify-content: center; /* Vertikální zarovnání obsahu */
}

/* ================================================================== */
/* === ZDE JSOU PŘIDANÉ OPRAVY === */
/* ================================================================== */

/* === NOVÝ STYL: Tlačítko pro označení mapy === */
.flag-map-btn {
    /* Základní styly jsou inline v PHP, zde jsou interakce */
    transition: var(--transition-main);
}
.flag-map-btn:hover:not(:disabled) {
    background-color: var(--bg-light) !important; /* Přepis inline stylu */
    color: var(--text-primary) !important;
    border-color: var(--accent-secondary) !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(0, 191, 255, 0.2);
}
.flag-map-btn:disabled {
    opacity: 0.7;
    cursor: not-allowed;
}

/* === NOVÝ STYL: Box pro již propojenou mapu === */
.map-link-box {
    display: flex;
    align-items: center;
    gap: 15px;
    padding: 20px;
    background-color: var(--accent-secondary);
    color: var(--bg-dark);
    text-decoration: none;
    border-radius: var(--border-radius-main);
    transition: var(--transition-main);
    border: 1px solid var(--accent-secondary);
}
.map-link-box:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 20px rgba(0, 191, 255, 0.4);
    filter: brightness(1.1); /* Mírné zesvětlení */
}
.map-link-box i {
    font-size: 2rem;
    flex-shrink: 0;
}
.map-link-box div {
    display: flex;
    flex-direction: column;
}
.map-link-box .map-link-label {
    font-size: 0.9em;
    opacity: 0.8;
    font-weight: 700;
}
.map-link-box strong {
    font-size: 1.1em;
    color: var(--bg-dark);
    line-height: 1.3;
}
/* ================================================================== */
/* === KONEC PŘIDANÝCH OPRAV === */
/* ================================================================== */


/* Responzivita pro novou sekci */
@media (max-width: 900px) {
    .community-feedback .feedback-grid { 
        grid-template-columns: 1fr; 
    }
    .map-link { 
        border-left: none; 
        padding-left: 0; 
        border-top: 2px solid var(--border-color); 
        padding-top: 30px; 
        margin-top: 20px;
    }
    .status-option {
        grid-template-columns: 100px 1fr 70px; /* Úprava pro mobily */
        gap: 8px;
    }
    .status-label {
        font-size: 1em;
    }
}