:root {
    --md-sys-color-surface: #FEF7FF;
    --md-sys-color-on-surface: #1D1B20;
    --md-sys-color-surface-container: #F3EDF7;
    --md-sys-color-primary-container: #EADDFF;
    --md-sys-color-on-primary-container: #21005D;
    --md-sys-color-outline: #79747E;
}

body.dark-mode {
    --md-sys-color-surface: #1C1B1F;
    --md-sys-color-on-surface: #E6E1E5;
    --md-sys-color-surface-container: #2B2930;
    --md-sys-color-primary-container: #4F378B;
    --md-sys-color-on-primary-container: #EADDFF;
    --md-sys-color-outline: #938F99;
}

/* --- APP LOADING SCREEN --- */
#app-loading-screen {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: #141218; /* Tvoja hlavná tmavá farba webu */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 9999; /* Zabezpečí, že to bude úplne navrchu nad všetkým */
    transition: opacity 0.2s ease-out, visibility 0.2s;
}

/* Malý pekný kruhový loading indikátor */
.loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid var(--md-sys-color-surface-variant, #49454F);
    border-top: 4px solid var(--md-sys-color-primary, #D0BCFF); /* Tvoja M3 primárna farba */
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.user-menu-container {
    position: relative;
    display: inline-block;
	margin-left: auto;
}

.user-menu-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--md-sys-color-on-surface);
	width: 40px;
    height: 40px;
    border-radius: 50%;
    transition: background-color 0.2s;
}

/* Pridáme pekný M3 hover efekt pre tlačidlo */
.user-menu-btn:hover {
    background-color: rgba(0, 0, 0, 0.08);
}
body.dark-mode .user-menu-btn:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

#default-user-icon {
    /* Nastavenie rozmerov boxu ikony */
    width: 32px;
    height: 32px;
    
    /* 🚀 KLÚČ K DOKONALÉMU VYCENTROVANIU: Flexbox vnútri ikony */
    display: flex;
    align-items: center;
    justify-content: center;
    
    /* Aby veľkosť samotného symbolu vyplnila celý tento 32px priestor */
    font-size: 32px; 
    line-height: 1;
}

#user-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid transparent;
}

#user-avatar:hover { border-color: #007bff; }

.user-dropdown {
    position: absolute;
    top: 120%;
    right: 0;
    background-color: var(--md-sys-color-surface-container);
    min-width: 150px;
    box-shadow: 0px 8px 16px rgba(0,0,0,0.1);
    border-radius: 8px;
    overflow: hidden;
    z-index: 1000;
    display: flex;
    flex-direction: column;
}

.user-dropdown.hidden { display: none; }

.dropdown-item {
    padding: 12px 16px;
    background: none;
    border: none;
    text-align: left;
    cursor: pointer;
    font-size: 14px;
    width: 100%;
	color: var(--md-sys-color-on-surface);
    font-family: inherit; /* Udrží tvoj font Raleway */
    transition: background-color 0.15s ease;
}

.dropdown-item:hover { background-color: rgba(230, 225, 229, 0.08); }

body:not(.dark-mode) .dropdown-item:hover { 
    background-color: rgba(29, 27, 32, 0.08); 
}

.drawer-content { flex-grow: 1; }

.drawer-footer {
    padding: 16px;
	padding-bottom: calc(16px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--md-sys-color-outline);
    margin-top: auto;
}

.theme-switch-container {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    color: var(--md-sys-color-on-surface);
}

.switch {
    position: relative;
    display: inline-block;
    width: 52px;
    height: 32px;
    margin-left: auto;
}

.switch input { opacity: 0; width: 0; height: 0; }

.slider {
    position: absolute;
    cursor: pointer;
    top: 0; left: 0; right: 0; bottom: 0;
    background-color: var(--md-sys-color-outline);
    transition: .4s;
    border-radius: 32px;
}

.slider:before {
    position: absolute;
    content: "";
    height: 24px;
    width: 24px;
    left: 4px;
    bottom: 4px;
    background-color: white;
    transition: .4s;
    border-radius: 50%;
}

input:checked + .slider { background-color: var(--md-sys-color-primary-container); }
input:checked + .slider:before {
    transform: translateX(20px);
    background-color: var(--md-sys-color-on-primary-container);
}

body {
    margin: 0;
    font-family: "Raleway", sans-serif;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    background-color: var(--md-sys-color-surface);
    transition: background-color 0.3s ease, color 0.3s ease;
    color: var(--md-sys-color-on-surface);
    display: flex;
    min-height: 100vh;
}

.material-symbols-rounded {
    font-size: 24px;
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    vertical-align: middle;
}

.drawer-item.active .material-symbols-rounded {
    font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

/* Top App Bar */
.top-app-bar {
    height: 64px;
    background-color: rgba(254, 247, 255, 0.85) !important; /* Svetlý režim */
	backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    display: flex;
    align-items: center;
    padding: 0 16px;
    position: fixed;
    top: 0; right: 0; left: 0;
    z-index: 80;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
	/* Zabezpečenie hladkého prechodu pri prepínaní tém */
    transition: background-color 0.3s ease;
}

/* Úprava pre tmavý režim (Dark Mode) */
body.dark-mode .top-app-bar {
    /* Polopriehľadné tmavé M3 pozadie s rovnakým 85% krytím */
    background-color: rgba(28, 27, 31, 0.85) !important;
    box-shadow: none !important;
}

.logo-link {
    display: flex;
    align-items: center;
    height: 100%;
    text-decoration: none;
    margin-left: 8px;
}

.app-logo {
    height: 32px;
    width: auto;
    object-fit: contain;
}

.icon-button {
    background: none;
    border: none;
    color: var(--md-sys-color-on-surface);
    cursor: pointer;
    padding: 12px;
    border-radius: 50%;
    transition: background-color 0.2s;
}

.icon-button:hover { background-color: rgba(255,255,255,0.08); }

.main-content {
    flex-grow: 1;
    margin-top: 64px;
    padding: 24px;
    transition: margin-left 0.3s ease;
    min-width: 0;
    box-sizing: border-box;
}

/* Navigation Drawer */
.navigation-drawer {
    width: 280px;
    min-width: 280px;
    height: 100dvh;
    background-color: var(--md-sys-color-surface-container);
    position: fixed; 
    left: -285px; top: 0;
    transition: left 0.3s ease;
    z-index: 100;
    border-radius: 0 36px 0px 0;
    padding: 12px;
    box-sizing: border-box;
	display: flex;
    flex-direction: column;
}

.navigation-drawer.open { left: 0; }

@media (min-width: 900px) {
    .navigation-drawer {
        position: sticky; 
        left: 0; top: 64px;
        height: calc(100vh - 64px);
    }
    #menuBtn { display: none; }
}

.drawer-content { display: flex; flex-direction: column; gap: 4px; }

.drawer-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 16px;
    height: 56px;
    border-radius: 28px;
    text-decoration: none;
    color: var(--md-sys-color-on-surface);
}

.drawer-item:hover { background-color: rgba(255,255,255,0.08); }
.drawer-item.active {
    background-color: var(--md-sys-color-primary-container);
    color: var(--md-sys-color-on-primary-container);
}

/* Domovská stránka */
.home-container {
    max-width: 900px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.display-medium {
    font-size: 45px;
    font-weight: 800;
    color: var(--md-sys-color-on-surface);
    margin-bottom: 12px;
}

.home-hero-card {
    background-color: var(--md-sys-color-surface-container);
    border-radius: 28px;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}

.home-hero-img {
    width: 100%;
    aspect-ratio: 16 / 9;
    display: block;
    object-fit: cover;
}

.home-text {
    padding: 32px;
    font-size: 18px;
    line-height: 1.6;
    color: var(--md-sys-color-on-surface);
}

/* Mriežka článkov */
.cards-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(500px, 100%), 1fr));
    gap: 16px;
    justify-content: center;
    max-width: 1200px;
    margin: 0 auto;
}

.card {
    display: flex;
    background-color: var(--md-sys-color-surface-container);
    border-radius: 72px;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s, background-color 0.2s;
    border: 1px solid rgba(255,255,255,0.05);
    height: 180px;
    margin-bottom: 8px;
}

.card:hover {
    transform: translateY(-2px);
    background-color: rgba(255,255,255,0.08);
}

.card-image-container { height: 100%; aspect-ratio: 4 / 5; flex-shrink: 0; }
.card img { width: 100%; height: 100%; object-fit: cover; }
.card-content { padding: 16px 32px 16px 16px; display: flex; flex-direction: column; justify-content: center; overflow: hidden; }

.card-content h3 {
    margin: 0 0 8px 0;
    font-size: 18px;
    color: var(--md-sys-color-on-surface);
    display: -webkit-box;
    -webkit-line-clamp: 2; /* Maximálny počet riadkov, kým text zalomí. Potom dá bodky */
    -webkit-box-orient: vertical;  
    overflow: hidden;
    white-space: normal;
}

.card-content p {
    margin: 0; font-size: 14px; color: var(--md-sys-color-outline);
    display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}

/* Podstránka článku */
.article-page-container { max-width: 900px; margin: 10px auto; padding: 0px; box-sizing: border-box; }

.back-btn {
    background: var(--md-sys-color-surface-container);
    border: none; color: var(--md-sys-color-on-surface);
    cursor: pointer; padding: 10px 20px; border-radius: 20px;
    font-family: inherit; font-weight: 600;
    display: inline-flex; align-items: center; gap: 8px;
    margin-bottom: 32px; transition: transform 0.2s, background-color 0.2s;
}
.back-btn:hover {
    background-color: var(--md-sys-color-primary-container);
    color: var(--md-sys-color-on-primary-container);
    transform: translateX(-4px);
}

/* NOVÝ UNIVERZÁLNY MODAL SYSTÉM */
.modal-overlay {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
    padding: 24px;
    box-sizing: border-box;
}

.modal-window {
    background-color: var(--md-sys-color-surface-container);
    border-radius: 28px;
    position: relative;
    max-width: 650px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    padding: 48px;
	overflow: hidden;
    box-shadow: 0 16px 48px rgba(0,0,0,0.5);
    border: 0px solid rgba(255,255,255,0.08);
    box-sizing: border-box;
}

/* 2. Keď je v modále karta, okno stratí farbu a tvar */
.modal-window.card-mode {
    background: transparent !important;
    box-shadow: none !important;
    padding: 60px 40px 40px 40px; /* Väčší padding zhora, aby uvoľnil miesto krížiku */
    overflow: visible; /* Aby 3D efekty nič neodrezávalo */
}

/* 3. Posunutie close buttonu vyššie a napravo nad kartu */
.modal-window.card-mode .modal-close-icon {
    position: absolute;
    top: 10px;
    right: 10px;
    background: rgba(255, 255, 255, 0.1); /* Jemný sklenený krúžok okolo krížika */
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    transition: background 0.2s;
}

.modal-window.card-mode .modal-close-icon:hover {
    background: rgba(255, 255, 255, 0.25);
}

.modal-close-icon {
    position: absolute;
    top: 16px; right: 16px;
    background: none; border: none;
    color: var(--md-sys-color-on-surface);
    cursor: pointer; padding: 8px;
    border-radius: 50%;
    z-index: 10;
    transition: background-color 0.2s;
}
.modal-close-icon:hover { background-color: rgba(255,255,255,0.1); }

/* Tilt kontajner vo vnútri modálu nemá pozadie ani striktnú šírku */
.tilt-container { perspective: 1000px; display: flex; justify-content: center; touch-action: none; cursor: grab; }
.tilt-container:active { cursor: grabbing; }

#modal-tilt-wrapper {
    position: relative; border-radius: 999px; line-height: 0;
    box-shadow: 0 12px 36px rgba(0,0,0,0.5); transition: transform 0.1s ease-out; will-change: transform;
}

#modal-hero-img { display: block; max-height: 60vh; max-width: 100%; border-radius: 999px; object-fit: contain; }

.tilt-target::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(115deg, transparent 10%, rgba(255,105,180,0.4) 30%, rgba(0,255,255,0.5) 45%, rgba(255,255,255,0.8) 50%, rgba(0,255,255,0.5) 55%, rgba(255,215,0,0.4) 70%, transparent 90%);
    background-size: 200% 200%; background-position: var(--holo-x, 50%) var(--holo-y, 50%);
    display: none; opacity: 0; transition: opacity 0.2s ease; pointer-events: none; z-index: 2; mix-blend-mode: overlay;
}
.is-tilting .tilt-target::after { display: block; opacity: 1; }

.markdown-body h1 { font-size: 28px; margin-bottom: 16px; font-weight: 800; }
.markdown-body p { font-size: 16px; line-height: 1.6; margin-bottom: 12px; }
.markdown-body ul { padding-left: 20px; line-height: 1.6; }

/* Scrim a Album */
.scrim { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 90; opacity: 0; transition: opacity 0.3s ease; }
.scrim.show { display: block; opacity: 1; }

.album-container { max-width: 900px; margin: 30px auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 0 8px; }

.album-card {
    cursor: pointer; background-color: var(--md-sys-color-surface-container); border-radius: 999px; padding: 8px;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    aspect-ratio: 4 / 5; transition: transform 0.2s, box-shadow 0.2s; border: 1px solid rgba(255,255,255,0.05); box-sizing: border-box;
}
.album-card:hover { transform: scale(1.05); box-shadow: 0 8px 16px rgba(0,0,0,0.3); }
.album-card img { width: 100%; height: 100%; object-fit: cover; border-radius: 999px; }
.album-card.empty-card { border: 2px dashed var(--md-sys-color-outline); background-color: rgba(0, 0, 0, 0.1); color: var(--md-sys-color-outline); }
.album-card .placeholder-question { font-size: 3rem; font-weight: 300; user-select: none; }

.card-number-badge {
    font-size: 0.8rem;
    color: var(--md-sys-color-outline); /* Použije farbu z tvojej Material témy */
    margin-top: 8px;
    font-weight: 500;
    opacity: 0.7;
}

/* ========================================================
   OPRAVA PRE KRUHOVÉ KARTY A HOLO EFEKT V MODÁLE
   ======================================================== */

/* Tento blok v kóde nemáš a presne ten chýba, aby maskoval všetko do kruhu */
.tilt-target {
    border-radius: 999px !important; /* Vynúti kruhový tvar obalu */
    overflow: hidden !important;    /* 🚀 KĽÚČOVÉ: Nemilosrdne odreže štvorcové rohy holo efektu */
    position: relative;
}

/* Toto prepíše tvoje doterajšie nastavenia pre obrázok v modále na dokonalý kruh */
#modal-hero-img {
    border-radius: 999px !important;
    width: 100%;
    height: 100%;
    display: block;
}

/* Toto zaistí, že aj holo vrstva (lesk) bude vedieť, že má byť kruhová */
.tilt-target::after {
    border-radius: 999px !important;
}

@media (max-width: 600px) {
    .album-container { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .modal-window { padding: 20px; }
}

/* ========================================================
   MATERIAL DESIGN 3 DIALOG STYLES
   ======================================================== */

/* Úprava okna modálu, keď funguje ako M3 Dialog */
.modal-window.m3-dialog-mode {
    /* 🚀 OPRAVA: Použijeme kontajnerovú farbu, ktorá je v Light Mode svetlá a v Dark Mode tmavá */
    background-color: var(--md-sys-color-surface-container) !important; 
    border-radius: 28px !important;
    padding: 24px !important;
    max-width: 560px;
    min-width: 280px;
    /* 🚀 Jemnejší tieň, aby v light mode nevyzeral príliš agresívne */
    box-shadow: 0px 4px 12px rgba(0, 0, 0, 0.1), 0px 12px 32px rgba(0, 0, 0, 0.15);
    overflow: hidden;
}

/* Skrytie klasického zatváracieho krížika pre dialógy */
.modal-window.m3-dialog-mode .modal-close-icon {
    display: none;
}

/* Vnútorné usporiadanie elementov */
.m3-dialog-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

/* M3 Ikona v dialógu */
.m3-dialog-icon {
    font-size: 24px;
    /* 🚀 Dynamická farba pre ikonu, ktorá dobre kontrastuje v oboch režimoch */
    color: var(--md-sys-color-outline); 
    margin-bottom: 16px;
}

/* M3 Headline (Nadpis) */
.m3-dialog-title {
    font-family: 'Raleway', sans-serif;
    font-size: 24px;
    font-weight: 400;
    line-height: 32px;
    /* 🚀 Hlavná farba textu (v light mode tmavá, v dark mode svetlá) */
    color: var(--md-sys-color-on-surface);
    margin: 0 0 16px 0;
}

/* M3 Supporting Text (Hlavný text správ) */
.m3-dialog-text {
    font-size: 14px;
    letter-spacing: 0.25px;
    line-height: 20px;
    /* 🚀 Sekundárna farba textu pre popisy podľa Material špecifikácie */
    color: var(--md-sys-color-outline);
    margin: 0 0 24px 0;
}

/* Akčná sekcia pre tlačidlá vpravo dole */
.m3-dialog-actions {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}

/* M3 Text Button (Čisté textové tlačidlo) */
.m3-btn-text {
    background: transparent;
    border: none;
    font-family: 'Raleway', sans-serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.1px;
    /* 🚀 Tlačidlo získa správnu fialovú z témy. V light mode sýtejšiu, v dark mode svetlejšiu */
    color: var(--md-sys-color-on-primary-container); 
    padding: 10px 12px;
    border-radius: 100px;
    cursor: pointer;
    transition: background 0.2s, opacity 0.2s;
}

/* Efekt pri prejdení myšou cez tlačidlo */
.m3-btn-text:hover {
    background-color: rgba(0, 0, 0, 0.05);
    opacity: 0.9;
}

/* Malá poistka pre hover efekt tlačidla v tmavom režime */
body.dark-mode .m3-btn-text:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

/* ========================================================
   MATERIAL DESIGN 3: OUTLINED TEXT FIELD & BUTTON
   ======================================================== */

/* Hlavný kontajner nad albumom */
.m3-code-container {
    max-width: 500px;
    margin: 24px auto 32px auto;
    display: flex !important;   /* Vynútime flexbox, keď JS zmení display na block */
    flex-direction: row;        /* Na PC pôjdu striktne vedľa seba */
    align-items: center;
    justify-content: space-between;
    gap: 16px;                  /* 🚀 Fixná medzera medzi inputom a buttonom */
    padding: 0 16px;
    box-sizing: border-box;
}

/* Wrapper pre textové pole */
.m3-text-field-outlined {
    position: relative;
    flex-grow: 1;               /* Input vyplní všetok voľný časť riadku */
    height: 56px;
}

/* Samotný Input */
.m3-text-field-outlined input {
    width: 100%;
    height: 100%;
    background: transparent;
    border: 1px solid var(--md-sys-color-outline);
    border-radius: 28px;         /* M3 špecifikácia pre outlined polia */
    padding: 8px 16px;
    font-size: 16px;
    color: var(--md-sys-color-on-surface);
    outline: none;
    box-sizing: border-box;
    transition: border-color 0.2s, border-width 0.1s;
}

/* Štítok (Label), ktorý pláva */
.m3-text-field-outlined label {
    position: absolute;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    background-color: var(--md-sys-color-surface); /* Prekryje čiaru za ním */
    padding: 0 4px;
    font-size: 16px;
    color: var(--md-sys-color-outline);
    pointer-events: none;
    transition: transform 0.2s, top 0.2s, font-size 0.2s, color 0.2s;
}

/* --- ANIMÁCIA / CHOVANIE PRI FOCUSE A ZADANOM TEXTE --- */
.m3-text-field-outlined input:focus {
    border-color: #6750a4;
    border-width: 2px;
}

/* Keď je pole aktívne alebo obsahuje text, štítok vyletí na hornú linku */
.m3-text-field-outlined input:focus ~ label,
.m3-text-field-outlined input:not(:placeholder-shown) ~ label {
    top: 0;
    font-size: 12px;
    color: #6750a4;
    transform: translateY(-50%) scale(1);
}

body.dark-mode .m3-text-field-outlined label {
    background-color: #1C1B1F; /* Natvrdo zladené s tvojou tmavou témou */
}

/* --- M3 FILLED BUTTON --- */
.m3-btn-filled {
    height: 56px;
    padding: 0 24px;
    border: none;
    border-radius: 100px;       /* Plne zaoblené M3 tlačidlo */
    background-color: #6750a4;
    color: #ffffff;
    font-family: 'Raleway', sans-serif;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.1px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    white-space: nowrap;        /* 🚀 ZÁKAZ ZALOMENIA TEXTU: Tlačidlo sa na PC nesmie scvrknúť */
    flex-shrink: 0;             /* Tlačidlo si drží svoju plnú šírku */
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15);
    transition: box-shadow 0.2s, background-color 0.2s;
}

.m3-btn-filled .material-symbols-rounded {
    font-size: 18px;
}

.m3-btn-filled:hover {
    background-color: #533d8b;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.15), 0px 2px 6px rgba(0, 0, 0, 0.3);
}

/* Zoznam albumov — dlaždice */
.album-list-container {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 16px;
    padding: 16px 8px;       /* 8px na bokoch, aby to presne lícovalo s paddingom kariet */
    max-width: 900px;        /* Obmedzenie šírky na tvojich 900px */
    margin: 0 auto;          /* Vycentrovanie celého kontajnera na stred */
    box-sizing: border-box;
}

.album-tile {
    background: var(--md-sys-color-surface-container);
    border-radius: 16px;
    padding: 20px;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s;
    text-align: center;
}

.album-tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

.album-tile h3 {
    margin: 0 0 8px;
    font-size: 1rem;
}

.album-tile p {
    margin: 0;
    font-size: 0.85rem;
    opacity: 0.7;
}

/* Flexbox riadok pre zarovnanie vedľa seba a vycentrovanie s mriežkou */
.album-title-row {
    max-width: 900px;         /* Rovnaká šírka ako .album-container */
    margin: 20px auto 16px;   /* Vycentrovanie na stred stránky */
    padding: 0 8px;           /* Lícovanie s okrajom kariet */
    display: flex;
    align-items: center;      /* Vertikálne vycentrovanie šípky s textom */
    gap: 12px;                /* Medzera medzi šípkou a názvom */
    box-sizing: border-box;
}

/* Štýl pre okrúhlu šípku späť */
.album-back-icon-btn {
    background: none;
    border: none;
    color: var(--md-sys-color-on-surface);
    cursor: pointer;
    width: 48px;
    height: 48px;
    border-radius: 50%;       /* Dokonalý kruh */
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s, transform 0.2s;
    padding: 0;
}

/* Hover efekt pre šípku */
.album-back-icon-btn:hover {
    background-color: rgba(0, 0, 0, 0.08);
    transform: translateX(-2px); /* Jemný posun vľavo pre lepší pocit z navigácie */
}

/* Hover efekt pre šípku v tmavom režime */
body.dark-mode .album-back-icon-btn:hover {
    background-color: rgba(255, 255, 255, 0.08);
}

/* Resetujeme pôvodný margin nadpisu, keďže je teraz vo flexboxe */
#album-detail-title {
    margin: 0;
    font-size: 32px;
    font-weight: 800;
    line-height: 1;
}

/* Pozadie progress baru (čiara vnútri dlaždice albumu) */
.album-progress-bar-bg {
    width: 100%;
    height: 6px;
    background-color: rgba(0, 0, 0, 0.1); /* Jemná sivá pre svetlý režim */
    border-radius: 3px;
    margin-top: 8px;
    overflow: hidden; /* Oseknutie okrajov výplne */
}

/* Úprava pozadia pre tvoj tmavý režim (dark-mode) */
body.dark-mode .album-progress-bar-bg {
    background-color: rgba(255, 255, 255, 0.15); /* Viditeľnejšia sivá v tme */
}

/* Zelená výplň progress baru */
.album-progress-bar-fill {
    height: 100%;
    background-color: #4CAF50; /* Príjemná zelená */
    border-radius: 3px;
    transition: width 0.4s ease-out; /* Animácia pri načítaní */
}

/* Zacielime na všetky obrázky vnútri tela článku */
#full-article-body img {
    /* 1. PRISPÔSOBENIE ROZLÍŠENIU (Responsiveness) */
    max-width: 100%;    /* Obrázok sa nikdy neroztiahne na šírku viac, než má samotný článok */
    height: auto;       /* Výška sa automaticky dopočíta, aby sa obrázok nedeformoval */
    display: block;     /* Odstráni drobné prázdne miesto pod obrázkom */
    
    /* 2. ZAOBLENÉ OKRAJE */
    border-radius: 12px; /* Hodnotu (napr. 8px, 12px, 16px) si uprav podľa toho, ako veľmi ich chceš zaobliť */
    
    /* TIP: Estetické vylepšenia (voliteľné) */
    margin: 24px auto;  /* Pekne odsadí obrázok od textu zhora/zdola a vycentruje ho na stred */
    
}

/* --- PROFIL PROGRESS BAR (M3 Green) --- */

/* Pozadie progress baru - sivý kontajner */
.progress-bar-bg {
    width: 100%;
    height: 8px;
    background-color: var(--md-sys-color-surface-container);
    border-radius: 4px;
    overflow: hidden;
    margin-top: 8px;
}

/* Výplň progress baru - rovnaká zelená ako pri albumoch */
.progress-bar-fill {
    height: 100%;
    width: 0%; /* Dynamicky mení JavaScript */
    background-color: #4CAF50; /* Tvoja overená zelená */
    border-radius: 4px;
    transition: width 0.3s ease-in-out; /* Hladká animácia pri načítaní */
}

/* Jemné formátovanie textov nad progress barom */
.progress-text-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.9rem;
    color: var(--md-sys-color-on-surface);
    margin-top: 12px;
}

/* --- OBMEDZENIE ŠÍRKY PROFILU --- */
.profile-container {
    max-width: 900px;
    margin: 0 auto;       /* Vycentruje celú stránku na stred */
    padding: 16px;        /* Zabezpečí, že na mobile sa nenalepí na okraj */
    box-sizing: border-box;
}

/* Kruhový avatar pre profilovú stránku */
.profile-avatar-large {
    width: 96px;
    height: 96px;
    border-radius: 50%;       /* Toto vytvorí z obrázka dokonalý kruh */
    object-fit: cover;        /* Zabezpečí, že sa fotka nestlačí ani neroztiahne */
    display: block;           /* Odstráni prípadné voľné pixely pod obrázkom */
}


/* Kontajner pre štatistiky */
.profile-stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 20px;
    width: 100%;
}

/* Štýl pre jednotlivé karty štatistík (M3 Surface Variant) */
.stat-card {
    background-color: var(--md-sys-color-surface-variant);
    border-radius: 12px; /* M3 stredné zaoblenie */
    padding: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--md-sys-color-outline-variant, #49454f);
}

/* Písmeno (C, T, Z) */
.stat-label {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--md-sys-color-primary);
    margin-bottom: 4px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Výsledné sčítané číslo */
.stat-value {
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--md-sys-color-on-surface-variant, var(--md-sys-color-on-surface));
}

/* Prispôsobenie pre malé mobily */
@media (max-width: 400px) {
    .profile-stats-grid {
        gap: 8px;
    }
    .stat-value {
        font-size: 1.2rem;
    }
}

/* --- Media Query pre mobily (Zalomenie pod seba) --- */
@media (max-width: 550px) {
    .m3-code-container {
        flex-direction: column !important; /* Na mobile prehodíme do stĺpca */
        align-items: stretch !important;   /* Roztiahne prvky na rovnakú šírku */
        gap: 16px;                         /* Väčšia vertikálna medzera na prst */
    }
    .m3-text-field-outlined {
        width: 100%;
    }
    .m3-btn-filled {
        width: 100%;
        height: 56px;                      /* Pohodlnejšie stlačenie na mobile */
    }
}

/* Vypnutie modrého záblesku po kliknutí na mobilných zariadeniach */
* {
    -webkit-tap-highlight-color: transparent;
}
