/* css/style.css - Kompletní verze */

/* ==========================================================================
   Základní nastavení a proměnné pro tmavý design
   ========================================================================== */
:root {
    --dark-bg: #1e2124;
    --header-bg: #282b30;
    --table-bg: #36393f;
    --border-color: #42454a;
    --text-color: #dcddde;
    --text-muted: #a0a1a4;
    --green-color: #28a745;
    --link-color: #7289da;
    --danger-color: #c82333;
}

/* ==========================================================================
   Styly pro PŘIHLAŠOVACÍ stránku (login.php)
   ========================================================================== */
body.login-page {
    font-family: 'Roboto', sans-serif;
    background-color: #f0f2f5;
    color: #333;
    margin: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100vw;
    height: 100vh;
}

.login-container {
    background-color: #ffffff;
    padding: 40px 50px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    text-align: center;
    max-width: 400px;
    width: 90%;
}

.login-container h1 {
    font-size: 24px;
    margin-top: 0;
    margin-bottom: 10px;
    color: #1c1e21;
}

.login-container p {
    font-size: 16px;
    margin-bottom: 30px;
    color: #606770;
}

.google-login-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 30px;
    background-color: var(--green-color); /* Používáme zelenou z proměnných */
    color: #ffffff;
    border: none;
    border-radius: 6px;
    font-size: 16px;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 0.3s ease, box-shadow 0.3s ease;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.google-login-button:hover {
    background-color: #218838;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.google-login-button svg {
    width: 20px;
    height: 20px;
    margin-right: 12px;
}

/* ==========================================================================
   Styly pro HLAVNÍ STRÁNKU (index.php) a další vnitřní stránky
   ========================================================================== */
body.dashboard-page {
    background-color: var(--dark-bg);
    color: var(--text-color);
    font-family: Arial, sans-serif;
    margin: 0;
}

.dashboard-page .main-header {
    background-color: var(--header-bg);
    padding: 15px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-color);
}

.dashboard-page .main-header h1 { margin: 0; font-size: 24px; }
.dashboard-page .container { padding: 20px 30px; }
.dashboard-page .filters { margin-bottom: 20px; display: flex; gap: 20px; align-items: center; }

.dashboard-page .filters select, 
.dashboard-page .filters input[type="checkbox"] {
    background-color: var(--table-bg);
    color: var(--text-color);
    border: 1px solid var(--border-color);
    padding: 8px 12px;
    border-radius: 5px;
}

.dashboard-page .checkbox-label { display: flex; align-items: center; gap: 8px; cursor: pointer; }

/* Společné styly pro tlačítka */
.btn { text-decoration: none; padding: 8px 15px; border-radius: 5px; color: #fff; font-weight: bold; transition: opacity .2s ease; border: none; cursor: pointer; }
.btn:hover { opacity: .85; }
.btn-primary { background-color: var(--link-color); }
.btn-secondary { background-color: #4f545c; }
.btn-danger { background-color: var(--danger-color); }

/* Tabulka */
.dashboard-page .table-container { background-color: var(--table-bg); border-radius: 8px; overflow-x: auto; }
.dashboard-page table { width: 100%; border-collapse: collapse; }
.dashboard-page th, .dashboard-page td { padding: 15px 20px; text-align: left; border-bottom: 1px solid var(--border-color); }
.dashboard-page thead th { background-color: var(--header-bg); font-size: 14px; text-transform: uppercase; color: var(--text-muted); }
.dashboard-page tbody tr:hover { background-color: var(--header-bg); cursor: pointer; }
.dashboard-page tbody tr:last-child td { border-bottom: none; }
.dashboard-page .lektor-schvaleno { color: var(--green-color); font-weight: bold; }
.dashboard-page .lektor-ceka_na_schvaleni { color: var(--text-muted); font-style: italic; }

/* Modální okno */
#modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,.7); display: none; justify-content: center; align-items: center; z-index: 1000; }
#modal-box { background-color: var(--table-bg); padding: 25px 35px; border-radius: 8px; width: 90%; max-width: 600px; position: relative; color: var(--text-color); border: 1px solid var(--border-color); }
#modal-close-btn { position: absolute; top: 10px; right: 15px; background: 0 0; border: none; color: var(--text-muted); font-size: 30px; cursor: pointer; }
#modal-content h2 { margin-top: 5px; color: #fff; }
#modal-content .kurz-id { font-size: 14px; color: var(--text-muted); }
#modal-content .kurz-info { line-height: 1.6; }
#modal-content hr { border: none; border-top: 1px solid var(--border-color); margin: 15px 0; }
.terminy-list .termin-item { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--border-color); }
.terminy-list .termin-item:last-child { border-bottom: none; }
.termin-den { color: var(--text-muted); }
.termin-lektor { font-size: 14px; color: var(--text-muted); }
.modal-actions { margin-top: 20px; display: flex; justify-content: space-between; }
.btn-reserve { background-color: var(--green-color); }
.btn-reserve:disabled { background-color: #5a625a; cursor: not-allowed; }
/* Styly pro formuláře */
.form-container {
    background-color: var(--table-bg);
    padding: 30px;
    border-radius: 8px;
    max-width: 700px;
    margin: 20px auto;
}

.form-group {
    margin-bottom: 20px;
}

.form-group label {
    display: block;
    margin-bottom: 8px;
    color: var(--text-muted);
    font-weight: bold;
}

.form-group input[type="text"],
.form-group select,
.form-group textarea {
    width: 100%;
    padding: 12px;
    background-color: var(--dark-bg);
    border: 1px solid var(--border-color);
    border-radius: 5px;
    color: var(--text-color);
    font-size: 16px;
    box-sizing: border-box; /* Důležité pro správné zobrazení šířky */
}

.form-group textarea {
    resize: vertical;
    min-height: 120px;
}
/* Styly pro detail kurzu a záložky */
.header-subtitle {
    font-size: 16px;
    color: var(--text-muted);
    font-weight: normal;
}

.tab-nav {
    border-bottom: 2px solid var(--border-color);
    margin-bottom: 20px;
}

.tab-link {
    background: none;
    border: none;
    color: var(--text-muted);
    padding: 15px 20px;
    font-size: 16px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    transition: all 0.2s ease;
}

.tab-link:hover {
    color: var(--text-color);
}

.tab-link.active {
    color: var(--link-color);
    border-bottom-color: var(--link-color);
}

.tab-content {
    display: none;
}

.tab-content.active {
    display: block;
}

.btn-sm {
    font-size: 12px;
    padding: 5px 10px;
    text-decoration: none;
    color: var(--text-color);
    background-color: #4f545c;
    border-radius: 4px;
}

.btn-sm.btn-secondary {
    background-color: var(--dark-bg);
}

.info-box {
    background-color: var(--table-bg);
    padding: 20px;
    border-radius: 8px;
    line-height: 1.7;
}
.info-box p {
    margin: 0 0 10px 0;
}
.form-row {
    display: flex;
    gap: 20px;
}
.form-row .form-group {
    flex: 1;
}
/* Styly pro modální okno správy lektorů */
.modal-box .checkbox-list {
    max-height: 300px;
    overflow-y: auto;
    border: 1px solid var(--border-color);
    padding: 15px;
    border-radius: 5px;
}

.modal-box .checkbox-list div {
    display: block;
    margin-bottom: 10px;
}

.modal-box .checkbox-list label {
    margin-left: 10px;
    cursor: pointer;
}
/* Přesunout společné styly pro modály, pokud již existují */
.modal-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,.7); display: flex; justify-content: center; align-items: center; z-index: 1000; }
.modal-box { background-color: var(--table-bg); padding: 25px 35px; border-radius: 8px; width: 90%; max-width: 600px; position: relative; color: var(--text-color); border: 1px solid var(--border-color); }
.modal-close-btn { position: absolute; top: 10px; right: 15px; background: 0 0; border: none; color: var(--text-muted); font-size: 30px; cursor: pointer; }

/* Styly pro status uživatele */
.status-active {
    color: var(--green-color);
    font-weight: bold;
}
.status-inactive {
    color: var(--danger-color);
}
/* Styly pro skupiny checkboxů a radio buttonů */
.checkbox-group div, .radio-group div {
    margin-bottom: 8px;
}
.checkbox-group label, .radio-group label {
    margin-left: 8px;
}
/* Styl pro odkaz na kurz v hlavní tabulce, aby vypadal jako běžný text */
.course-link {
    color: inherit; /* Přebere barvu od rodiče (buňky tabulky) */
    font-weight: normal;
    text-decoration: none;
}

.course-link:hover {
    text-decoration: underline; /* Při najetí myší se podtrhne pro přehlednost */
}
.term-cell {
    white-space: nowrap;      /* Zabrání zalamování textu */
    overflow: hidden;         /* Skryje text, který se nevejde do buňky */
    text-overflow: ellipsis;  /* Přidá "..." na konec, pokud se text nevejde */
    font-size: 14px;          /* Mírně zmenšíme písmo */
    max-width: 220px;         /* Omezíme maximální šířku, aby se ellipsis správně zobrazil */
}