/* ============================================================
   İş Yeri Hekimliği Sistemi — Ana Stil Dosyası
   ============================================================ */

:root {
    --blue-primary: #1565c0;
    --blue-dark: #1a3a6c;
    --blue-light: #e8f0fe;
    --blue-accent: #2196f3;
    --success: #2e7d32;
    --warning: #f57f17;
    --danger: #c62828;
    --text-dark: #1a1a2e;
    --text-muted: #6c757d;
    --border-color: #dee2e6;
    --card-shadow: 0 2px 8px rgba(0,0,0,0.08);
    --radius: 10px;
}

* {
    font-family: 'Inter', system-ui, sans-serif;
}

body {
    background-color: #f0f4f8;
    color: var(--text-dark);
}

/* ── Navbar ──────────────────────────────────────────────── */
.nav-link-pill {
    border-radius: 6px;
    padding: 6px 12px !important;
    font-size: 0.875rem;
    font-weight: 500;
    transition: background 0.2s;
}

    .nav-link-pill:hover {
        background: rgba(255,255,255,0.15);
    }

    .nav-link-pill.active {
        background: rgba(255,255,255,0.25) !important;
        font-weight: 600;
    }

/* ── Kartlar ─────────────────────────────────────────────── */
.card {
    border: 1px solid var(--border-color);
    border-radius: var(--radius);
    box-shadow: var(--card-shadow);
    background: white;
}

.card-header {
    background: white;
    border-bottom: 2px solid var(--blue-light);
    padding: 14px 20px;
    font-weight: 600;
    color: var(--blue-dark);
    border-radius: var(--radius) var(--radius) 0 0 !important;
}

/* ── İstatistik Kartları ─────────────────────────────────── */
.stat-card {
    border-radius: var(--radius);
    padding: 20px;
    color: white;
    position: relative;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

    .stat-card .icon {
        position: absolute;
        right: 16px;
        top: 50%;
        transform: translateY(-50%);
        font-size: 3rem;
        opacity: 0.2;
    }

    .stat-card .stat-num {
        font-size: 2rem;
        font-weight: 700;
        line-height: 1;
    }

    .stat-card .stat-label {
        font-size: 0.8rem;
        opacity: 0.9;
        margin-top: 4px;
    }

    .stat-card .stat-sub {
        font-size: 0.75rem;
        opacity: 0.75;
        margin-top: 8px;
    }

.stat-blue {
    background: linear-gradient(135deg, #1565c0, #1976d2);
}

.stat-green {
    background: linear-gradient(135deg, #2e7d32, #43a047);
}

.stat-orange {
    background: linear-gradient(135deg, #e65100, #f57c00);
}

.stat-purple {
    background: linear-gradient(135deg, #4527a0, #7b1fa2);
}

.stat-teal {
    background: linear-gradient(135deg, #006064, #00838f);
}

/* ── Tablo ───────────────────────────────────────────────── */
.table {
    font-size: 0.875rem;
}

    .table thead th {
        background: #f0f4f8;
        color: var(--blue-dark);
        font-weight: 600;
        border-bottom: 2px solid var(--blue-primary);
        font-size: 0.8rem;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        padding: 10px 14px;
    }

    .table tbody td {
        padding: 10px 14px;
        vertical-align: middle;
    }

    .table tbody tr:hover {
        background: #f8fbff;
    }

/* ── Badge'ler ───────────────────────────────────────────── */
.badge-calisabilir {
    background: #e8f5e9;
    color: #1b5e20;
    border: 1px solid #a5d6a7;
}

.badge-kisitli {
    background: #fff8e1;
    color: #e65100;
    border: 1px solid #ffe082;
}

.badge-calisabilir, .badge-kisitli {
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 600;
}

/* ── Muayene Tipi Renkleri ───────────────────────────────── */
.tip-ise-giris {
    background: #e3f2fd;
    color: #0d47a1;
}

.tip-periyodik {
    background: #f3e5f5;
    color: #4a148c;
}

.tip-ayrilma {
    background: #fce4ec;
    color: #880e4f;
}

.tip-ise-giris, .tip-periyodik, .tip-ayrilma {
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 0.75rem;
    font-weight: 600;
}

/* ── Formlar ─────────────────────────────────────────────── */
.form-label {
    font-weight: 500;
    font-size: 0.875rem;
    color: var(--text-dark);
}

.form-control, .form-select {
    border-radius: 7px;
    border: 1px solid #cdd5e0;
    font-size: 0.875rem;
    padding: 8px 12px;
    transition: border-color 0.2s, box-shadow 0.2s;
}

    .form-control:focus, .form-select:focus {
        border-color: var(--blue-primary);
        box-shadow: 0 0 0 3px rgba(21,101,192,0.12);
    }

.section-header {
    background: var(--blue-light);
    border-left: 4px solid var(--blue-primary);
    padding: 8px 14px;
    border-radius: 0 6px 6px 0;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--blue-dark);
    margin-bottom: 16px;
}

/* ── Butonlar ────────────────────────────────────────────── */
.btn-primary {
    background: var(--blue-primary);
    border-color: var(--blue-primary);
    border-radius: 7px;
}

    .btn-primary:hover {
        background: var(--blue-dark);
        border-color: var(--blue-dark);
    }

.btn-outline-primary {
    color: var(--blue-primary);
    border-color: var(--blue-primary);
    border-radius: 7px;
}

.btn {
    font-weight: 500;
    font-size: 0.875rem;
}

/* ── EK-2 Form ───────────────────────────────────────────── */
.ek2-section {
    border: 1px solid #b0c4de;
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 16px;
    background: #fafbfd;
}

.ek2-section-title {
    font-weight: 700;
    color: var(--blue-dark);
    border-bottom: 1px solid #b0c4de;
    padding-bottom: 8px;
    margin-bottom: 14px;
    font-size: 0.9rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ── Hatırlatma Kartları ─────────────────────────────────── */
.hatirlatma-card {
    border-left: 4px solid var(--warning);
    background: #fffde7;
    border-radius: 0 8px 8px 0;
    padding: 12px 16px;
    margin-bottom: 8px;
}

    .hatirlatma-card.acil {
        border-left-color: var(--danger);
        background: #ffebee;
    }

    .hatirlatma-card.normal {
        border-left-color: var(--blue-primary);
        background: var(--blue-light);
    }

/* ── Dashboard Timeline ──────────────────────────────────── */
.timeline-item {
    border-left: 2px solid var(--border-color);
    padding-left: 16px;
    margin-left: 8px;
    margin-bottom: 12px;
    position: relative;
}

    .timeline-item::before {
        content: '';
        position: absolute;
        left: -5px;
        top: 4px;
        width: 8px;
        height: 8px;
        border-radius: 50%;
        background: var(--blue-primary);
    }

/* ── Sayfalama ───────────────────────────────────────────── */
.page-link {
    color: var(--blue-primary);
    border-radius: 6px;
}

.page-item.active .page-link {
    background: var(--blue-primary);
    border-color: var(--blue-primary);
}

/* ── Print (PDF için) ────────────────────────────────────── */
@media print {
    .navbar, .footer, .btn, .alert {
        display: none !important;
    }

    .card {
        box-shadow: none !important;
        border: 1px solid #000 !important;
    }
}

/* ══════════════════════════════════════════════════════════════
   MOBİL UYUM
   ══════════════════════════════════════════════════════════════ */

/* Tablolar: mobilde yatay kaydırma (taşma engeli) */
.table-responsive-auto {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* ── Küçük ekranlar (< 768px) ── */
@media (max-width: 767.98px) {
    /* Genel */
    body {
        font-size: 0.85rem;
    }

    .container-fluid {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }

    h4 {
        font-size: 1.2rem;
    }

    h6 {
        font-size: 0.95rem;
    }

    /* Navbar */
    .navbar-brand {
        font-size: 0.9rem !important;
    }

    .nav-link-pill {
        padding: 8px 12px !important;
        font-size: 0.85rem;
    }

    .navbar .dropdown-menu {
        background: rgba(255,255,255,0.08);
        border: none;
    }

    .navbar .dropdown-item {
        color: rgba(255,255,255,0.9);
        font-size: 0.85rem;
        padding: 6px 16px;
    }

        .navbar .dropdown-item:hover {
            background: rgba(255,255,255,0.12);
        }

    /* Kartlar */
    .card {
        border-radius: 8px;
    }

    .card-header {
        padding: 10px 14px;
        font-size: 0.85rem;
    }

    .card-body {
        padding: 12px;
    }

    /* Dashboard istatistik kartları */
    .stat-card .stat-num {
        font-size: 1.4rem;
    }

    .stat-card .icon {
        font-size: 2rem;
    }

    /* Tablolar */
    .table {
        font-size: 0.78rem;
    }

        .table thead th {
            padding: 6px 8px;
            font-size: 0.7rem;
            letter-spacing: 0;
        }

        .table tbody td {
            padding: 6px 8px;
        }

    /* Butonlar */
    .btn {
        font-size: 0.8rem;
        padding: 6px 10px;
    }

    .btn-sm {
        font-size: 0.75rem;
        padding: 4px 8px;
    }

    .d-flex.gap-2 {
        gap: 0.35rem !important;
    }

    /* Formlar */
    .form-control, .form-select {
        font-size: 0.85rem;
        padding: 7px 10px;
    }

    .form-label {
        font-size: 0.8rem;
    }

    /* DataTables */
    .dataTables_wrapper .dataTables_filter,
    .dataTables_wrapper .dataTables_length {
        font-size: 0.8rem;
    }

    .dataTables_wrapper .dataTables_info {
        font-size: 0.75rem;
    }

    /* Sayfa başlığı: yatay → dikey */
    .d-flex.justify-content-between {
        flex-direction: column !important;
        gap: 0.5rem;
    }

    /* Toast */
    .toast-container {
        left: 8px;
        right: 8px;
    }

    .toast {
        font-size: 0.8rem;
    }

    /* Profil kartı */
    .tab-content {
        font-size: 0.82rem;
    }

    .nav-tabs .nav-link {
        font-size: 0.78rem;
        padding: 6px 10px;
    }

    /* Footer */
    footer {
        font-size: 0.75rem !important;
    }
}

/* ── Çok küçük ekranlar (< 576px) ── */
@media (max-width: 575.98px) {
    .container-fluid {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    h4 {
        font-size: 1.05rem;
    }

    /* İstatistik kartları daha kompakt */
    .card-body {
        padding: 10px;
    }

    /* Tablo sütun daraltma */
    .table thead th {
        white-space: nowrap;
    }

    /* Dropdown menü full genişlik */
    .navbar .dropdown-menu {
        margin-left: 0;
        margin-right: 0;
    }
}
