/* Google Fonts importálása */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;700&display=swap');

/* ============================================= */
/* =========== ALAP STÍLUSOK =================== */
/* ============================================= */

/* Alapszínek és betűtípus beállítása */
:root {
    --primary-color: #1cb6a9; /* Türkiz a honlapról */
    --primary-hover-color: #17a194;
    --text-color: #666666;
    --heading-color: #444444;
    --light-gray-bg: #f8f9fa;
    --danger-color: #dc3545;
    --warning-color: #ffc107;
    --dark-gray: #6c757d;
}

body { 
    font-family: 'Poppins', sans-serif; 
    background-color: #ffffff; 
    margin: 0; 
    padding: 20px; 
    color: var(--text-color);
}

/* Konténerek */
.container, .form-container { 
    max-width: 1200px; 
    margin: 0 auto; 
    background-color: white; 
    padding: 20px; 
    border-radius: 8px; 
}

/* Gombok */
.btn { padding: 10px 20px; border: none; border-radius: 4px; color: white; cursor: pointer; font-size: 16px; text-decoration: none; display: inline-block; margin: 0 5px; }
.btn-primary, .btn-add, .btn-save { background-color: var(--primary-color); } 
.btn-primary:hover, .btn-add:hover, .btn-save:hover { background-color: var(--primary-hover-color); }
.btn-success { background-color: #28a745; } .btn-success:hover { background-color: #218838; }
.btn-danger { background-color: var(--danger-color); } .btn-danger:hover { background-color: #c82333; }
.btn-edit { background-color: var(--warning-color); color: #212529; }
.btn-back { background-color: var(--dark-gray); } .btn-back:hover { background-color: #5a6268; }


/* Fejléc */
.page-header { display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid #ddd; padding-bottom: 10px; margin-bottom: 20px; }
.page-header .user-info { display: flex; align-items: center; gap: 20px; }
.page-header a { text-decoration: none; color: white; padding: 8px 15px; border-radius: 4px; }
.page-header a.logout { background-color: var(--danger-color); }
.page-header a.password { background-color: var(--dark-gray); }

/* Címek és szövegek */
h1, h2, h3, h4, h5, h6 { color: var(--heading-color); }

/* Bejelentkező oldal */
.login-container { max-width: 400px; margin: 40px auto; padding: 40px; border: 1px solid #eee; text-align: center; }
.login-container h1 { color: var(--heading-color); }
.login-container input[type="email"], .login-container input[type="password"] { width: 100%; padding: 12px; margin: 10px 0; border: 1px solid #ddd; border-radius: 4px; box-sizing: border-box; }
.login-container button { width: 100%; padding: 12px; background-color: var(--primary-color); color: white; border: none; border-radius: 4px; cursor: pointer; font-size: 16px; }
.login-container button:hover { background-color: var(--primary-hover-color); }
.login-container .error { color: var(--danger-color); margin-top: 10px; }

/* Üzenetek */
.message { padding: 15px; border-radius: 4px; margin: 20px 0; }
.message.success { background-color: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.message.error { background-color: #f8d7da; color: var(--danger-color); border: 1px solid #f5c6cb; }

/* Admin szekció és navigáció */
.admin-section { margin-top: 40px; border-top: 2px solid var(--primary-color); padding-top: 20px; }
.admin-section .admin-nav { background-color: var(--light-gray-bg); padding: 10px; margin-bottom: 20px; border-radius: 5px; display: flex; gap: 15px; flex-wrap: wrap; }
.admin-section .admin-nav a { text-decoration: none; font-weight: bold; color: var(--primary-color); padding: 8px; border-radius: 4px; }
.admin-section .admin-nav a:hover { background-color: #e2e6ea; }
.admin-section .admin-nav a.active { background-color: var(--primary-color); color: white; }

/* Listák */
.request-list-item, .summary-list-item { display: flex; justify-content: space-between; align-items: center; padding: 15px; border: 1px solid #ddd; border-radius: 8px; margin-bottom: 10px; flex-wrap: wrap;}
.request-info, .summary-info { display: flex; gap: 15px; align-items: center; flex-grow: 1; flex-wrap: wrap;}
.request-info span, .summary-info span { padding: 5px 10px; background-color: var(--light-gray-bg); border-radius: 5px; }
.request-actions { margin-left: auto; padding-left: 20px; }
.request-actions form { margin: 0; }
.request-actions .btn { margin-left: 10px; }

/* Szabadság statisztikák */
.leave-stats { display: flex; gap: 30px; margin-bottom: 30px; padding: 20px; background-color: var(--light-gray-bg); border-radius: 8px; justify-content: center; }
.stat-item { text-align: center; } 
.stat-item .number { font-size: 2em; font-weight: bold; } 
.stat-item .label { font-size: 1em; color: var(--dark-gray); }

/* Naptár */
.calendar-container { margin-top: 30px; text-align: center; }
.calendar-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 15px; }
.calendar-header h2 { margin: 0; font-size: 1.8em; color: var(--primary-color); }
.calendar-header .nav-link { text-decoration: none; padding: 8px 16px; background-color: var(--primary-color); color: white; border-radius: 4px; }
.calendar-header .nav-link:hover { background-color: var(--primary-hover-color); }
.calendar { width: 100%; border-collapse: collapse; table-layout: fixed; margin-bottom: 20px; }
.calendar th, .calendar td { border: 1px solid #ddd; padding: 5px; height: 120px; vertical-align: top; }
.calendar th.day-header { background-color: var(--light-gray-bg); font-weight: bold; text-align: center; }
.calendar td .day-number { font-weight: bold; margin-bottom: 5px; text-align: left; color: var(--heading-color); }
.calendar td.empty { background-color: #fafafa; border-color: transparent; }
.calendar td.weekend { background-color: var(--light-gray-bg); }
.calendar td.weekend .day-number { color: #aaa; }
.calendar td.today { background-color: #fffde7; }
.calendar td.holiday .day-number { color: var(--danger-color); font-weight: bold; }

/* Naptárbejegyzések */
.calendar-entry { padding: 4px; margin-top: 4px; border-radius: 4px; color: white; font-size: 0.8em; white-space: normal; word-wrap: break-word; text-align: center; }
a.delete-link { text-decoration: none; display: block; cursor: pointer; }
.entry-mandatory_leave { background-color: #6f42c1; }
.entry-public_holiday { background-color: var(--danger-color); }
.entry-event { background-color: #146c43; color: #a3e9a4; font-weight: bold; }

/* Űrlapok */
.request-form-container { background-color: var(--light-gray-bg); padding: 20px; border-radius: 8px; margin-top: 20px; border: 1px solid #ddd; }
.form-row { display: flex; align-items: center; gap: 15px; justify-content: center; }
.form-row label { font-weight: bold; }
.form-row input[type="date"] { padding: 8px; border-radius: 4px; border: 1px solid #ccc; }

.data-table { width: 100%; border-collapse: collapse; margin-top: 20px; }
.data-table th, .data-table td { border: 1px solid #ddd; padding: 12px; text-align: left; }
.data-table thead { background-color: var(--primary-color); color: white; }
.data-table tbody tr:nth-child(even) { background-color: #f2f2f2; }

.form-container { max-width: 800px; margin: 40px auto; background-color: white; padding: 30px; border-radius: 8px; }
.add-form, .edit-form { background-color: var(--light-gray-bg); padding: 20px; border-radius: 8px; margin-top: 20px; border: 1px solid #ddd; }
.form-group { margin-bottom: 15px; }
.form-group label { display: block; font-weight: bold; margin-bottom: 5px; }
.form-group label.required::after { content: ' *'; color: red; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 8px; border-radius: 4px; border: 1px solid #ccc; box-sizing: border-box; }
.form-group input[type="color"] { width: 100px; height: 40px; padding: 2px; cursor: pointer; }

.allowance-section { margin-top: 30px; padding-top: 20px; border-top: 1px solid #ddd; }
.allowance-list { list-style-type: none; padding: 0; }
.allowance-list li { background-color: #e9ecef; padding: 10px; border-radius: 4px; margin-bottom: 5px; }
.page-title { display: flex; justify-content: space-between; align-items: center; }

/* ============================================= */
/* =========== RESZPONZÍV STÍLUSOK ============ */
/* ============================================= */
@media (max-width: 768px) {
    body {
        padding: 10px;
        -webkit-text-size-adjust: 100%;
    }
    .container, .form-container {
        padding: 15px;
        margin: 10px auto;
    }
    .page-header {
        flex-direction: column;
        gap: 15px;
    }
    .request-list-item, .summary-list-item {
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }
    .request-info, .summary-info {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    .request-actions {
        margin-left: 0;
        padding-left: 0;
        width: 100%;
        display: flex;
        justify-content: flex-end;
    }
    .leave-stats {
        flex-direction: column;
        gap: 15px;
    }
    .calendar-header {
        flex-direction: column;
        gap: 10px;
    }
    .calendar th, .calendar td {
        height: 80px;
        padding: 2px;
        font-size: 0.8em;
    }
    .calendar-entry {
        font-size: 0.7em;
        padding: 2px;
    }
    .form-row, .add-form .form-group {
        display: block;
        margin-right: 0;
        margin-bottom: 15px;
    }
    .add-form .btn-add {
        width: 100%;
    }
}