/* === iOS SELECT DROPDOWN FIX ===
   iOS Safari'de native <select> dropdown'ları transform/scale uygulanmış
   parent elementlerde yanlış konumda açılabiliyor. Bu fix ile:
   - Select elementi için positioning context oluşturulur
   - Transform'lar normalize edilir
   - Dropdown doğru konumda açılır */
select {
    position: relative;
    -webkit-appearance: menulist-button;
}

@supports (-webkit-touch-callout: none) {
    /* iOS-specific select fixes */
    select {
        transform: translateZ(0);
        -webkit-transform: translateZ(0);
    }

    /* iOS PWA'da ek düzeltmeler */
    html.is-ios-pwa select,
    html.is-pwa select {
        position: relative;
        transform: none;
        -webkit-transform: none;
    }
}

/* ═══════════════════════════════════════════
   TEMA SİSTEMİ — CSS Custom Properties
   ═══════════════════════════════════════════ */

/* Caret (yanıp sönen yazı imleci) sadece gerçek yazı girişi olan alanlarda gözüksün.
   tabindex'li div, h2, button, sidebar vb. odaklanabilir elemanlarda caret gösterilmesin.
   !important ile başka kuralların override etmesi engellenir. */
*,
*::before,
*::after { caret-color: transparent !important; }

input,
textarea,
select,
[contenteditable="true"],
[contenteditable=""] { caret-color: auto !important; }

/* ═══ JS DOSYA YÜKLEME GÖSTERGESİ (Mesaj Kutusu) ═══ */
.js-file-loading {
    display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap;
    padding: 8px 16px; background: color-mix(in srgb, var(--t-accent, #6366f1) 6%, var(--t-card, #fff));
    border-bottom: 1px solid var(--t-card-border, #e2e8f0);
    animation: jfl-in 0.15s ease;
}
.js-file-loading .chat-ek-info { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.js-file-loading .chat-ek-icon { font-size: 1rem; flex-shrink: 0; }
.js-file-loading .chat-ek-ad {
    font-size: 0.78rem; font-weight: 600; color: var(--t-text, #1e293b);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.js-file-loading .upload-spin { display: inline-block; animation: jflSpin 1s linear infinite; }
.js-file-loading .upload-progress-bar {
    width: 100%; height: 3px; border-radius: 3px;
    background: var(--t-card-border, #e2e8f0); overflow: hidden; margin-top: 4px;
}
.js-file-loading .upload-progress-fill {
    height: 100%; border-radius: 3px;
    background: linear-gradient(90deg, var(--t-accent, #6366f1), #818cf8, var(--t-accent, #6366f1));
    background-size: 200% 100%;
    animation: jflFill 1.5s ease-in-out infinite;
}
@keyframes jfl-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
@keyframes jflSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes jflFill { 0% { width: 0%; background-position: 0% 0; } 50% { width: 70%; } 100% { width: 100%; background-position: -200% 0; } }

/* ═══ İNDİRME OVERLAY ═══ */
#dl-overlay{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:rgba(15,23,42,.45);backdrop-filter:blur(4px);animation:dlFadeIn .2s ease}
#dl-overlay.dl-fade-out{animation:dlFadeOut .35s ease forwards}
.dl-overlay-box{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px 48px;border-radius:18px;background:var(--t-card,#fff);box-shadow:0 20px 60px rgba(0,0,0,.18);text-align:center}
.dl-spinner{width:38px;height:38px;border:3.5px solid var(--t-card-border,#e2e8f0);border-top-color:var(--t-primary,#3b82f6);border-radius:50%;animation:dlSpin .7s linear infinite}
.dl-text{font-size:.92rem;font-weight:700;color:var(--t-text,#334155)}
.dl-file{font-size:.75rem;color:var(--t-text-muted,#94a3b8);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@keyframes dlSpin{to{transform:rotate(360deg)}}
@keyframes dlFadeIn{from{opacity:0}to{opacity:1}}
@keyframes dlFadeOut{from{opacity:1}to{opacity:0}}

:root {
    --t-bg: #f1f5f9;
    --t-body: #f1f5f9;
    --t-card: #ffffff;
    --t-card-border: #e2e8f0;
    --t-text: #1e293b;
    --t-text-muted: #64748b;
    --t-sidebar: #1e293b;
    --t-sidebar-head: #0f172a;
    --t-sidebar-active: #0ea5e9;
    --t-topbar: linear-gradient(135deg, #1e293b, #334155);
    --t-topbar-text: #f8fafc;
    --t-input-bg: #fcfdfe;
    --t-input-border: #cbd5e1;
    --t-accent: #6366f1;
    --t-accent-light: #eef2ff;
    --t-hover: #f8fafc;
    /* Masraf girişi — özet şeridi (aydınlık referans; koyu temada [data-theme] ile ezilir) */
    --mg-strip-bg: var(--t-card);
    --mg-strip-label: #334155;
    --mg-strip-note: #64748b;
    --mg-val-not-arrived: #2c3e50;
    --mg-val-arrived: #06b6d4;
    --mg-val-reported: #ea580c;
    --mg-val-debt: #ef4444;
    --mg-val-paid: #22c55e;
    --mg-val-total: #5b21b6;
    --mg-balance-box-bg: #f1f5f9;
    --mg-balance-value: #0f172a;
    --mg-balance-positive: #16a34a;
    --mg-balance-negative: #dc2626;
    /* Eğitimler — sertifika / muaf bilgi kutusu (aydınlık: mint yeşil) */
    --eg-cert-banner-bg: linear-gradient(135deg, #f0fdf4, #ecfdf5);
    --eg-cert-banner-border: #86efac;
    --eg-cert-banner-title: #166534;
    --eg-cert-banner-body: #64748b;
    /* Eğitimler — zorunlu içerik uyarı kutusu (amber) */
    --eg-warn-banner-bg: linear-gradient(135deg, #fffbeb, #fef3c7);
    --eg-warn-banner-border: #f59e0b;
    --eg-warn-banner-title: #92400e;
    --eg-warn-banner-body: #a16207;
}

/* ─── Gece ─── */
[data-theme="dark"] {
    --t-bg: #0f172a;
    --t-body: #0f172a;
    --t-card: #1e293b;
    --t-card-border: #334155;
    --t-text: #e2e8f0;
    --t-text-muted: #94a3b8;
    --t-sidebar: #020617;
    --t-sidebar-head: #000;
    --t-sidebar-active: #38bdf8;
    --t-topbar: linear-gradient(135deg, #020617, #0f172a);
    --t-topbar-text: #f1f5f9;
    --t-input-bg: #0f172a;
    --t-input-border: #334155;
    --t-accent: #38bdf8;
    --t-accent-light: #0c4a6e;
    --t-hover: #334155;
}
/* ─── Pembe ─── */
[data-theme="pink"] {
    --t-body: #fdf2f8;
    --t-card: #fff;
    --t-card-border: #fbcfe8;
    --t-text: #831843;
    --t-text-muted: #9d174d;
    --t-sidebar: #9d174d;
    --t-sidebar-head: #831843;
    --t-sidebar-active: #f472b6;
    --t-topbar: linear-gradient(135deg, #9d174d, #be185d);
    --t-topbar-text: #fdf2f8;
    --t-input-bg: #fff1f2;
    --t-input-border: #fda4af;
    --t-accent: #ec4899;
    --t-accent-light: #fce7f3;
    --t-hover: #fdf2f8;
}
/* ─── Okyanus ─── */
[data-theme="ocean"] {
    --t-body: #ecfeff;
    --t-card: #fff;
    --t-card-border: #a5f3fc;
    --t-text: #164e63;
    --t-text-muted: #0e7490;
    --t-sidebar: #155e75;
    --t-sidebar-head: #164e63;
    --t-sidebar-active: #22d3ee;
    --t-topbar: linear-gradient(135deg, #155e75, #0e7490);
    --t-topbar-text: #ecfeff;
    --t-input-bg: #f0fdfa;
    --t-input-border: #99f6e4;
    --t-accent: #06b6d4;
    --t-accent-light: #cffafe;
    --t-hover: #ecfeff;
}
/* ─── Orman ─── */
[data-theme="forest"] {
    --t-body: #f0fdf4;
    --t-card: #fff;
    --t-card-border: #bbf7d0;
    --t-text: #14532d;
    --t-text-muted: #166534;
    --t-sidebar: #14532d;
    --t-sidebar-head: #052e16;
    --t-sidebar-active: #4ade80;
    --t-topbar: linear-gradient(135deg, #14532d, #166534);
    --t-topbar-text: #f0fdf4;
    --t-input-bg: #f0fdf4;
    --t-input-border: #86efac;
    --t-accent: #22c55e;
    --t-accent-light: #dcfce7;
    --t-hover: #f0fdf4;
}
/* ─── Lavanta ─── */
[data-theme="lavender"] {
    --t-body: #faf5ff;
    --t-card: #fff;
    --t-card-border: #e9d5ff;
    --t-text: #3b0764;
    --t-text-muted: #6b21a8;
    --t-sidebar: #581c87;
    --t-sidebar-head: #3b0764;
    --t-sidebar-active: #c084fc;
    --t-topbar: linear-gradient(135deg, #581c87, #7c3aed);
    --t-topbar-text: #faf5ff;
    --t-input-bg: #faf5ff;
    --t-input-border: #d8b4fe;
    --t-accent: #a855f7;
    --t-accent-light: #f3e8ff;
    --t-hover: #faf5ff;
}
/* ─── Gün Batımı ─── */
[data-theme="sunset"] {
    --t-body: #fff7ed;
    --t-card: #fff;
    --t-card-border: #fed7aa;
    --t-text: #7c2d12;
    --t-text-muted: #c2410c;
    --t-sidebar: #9a3412;
    --t-sidebar-head: #7c2d12;
    --t-sidebar-active: #fb923c;
    --t-topbar: linear-gradient(135deg, #9a3412, #c2410c);
    --t-topbar-text: #fff7ed;
    --t-input-bg: #fff7ed;
    --t-input-border: #fdba74;
    --t-accent: #f97316;
    --t-accent-light: #ffedd5;
    --t-hover: #fff7ed;
}
/* ─── Gül Kurusu ─── */
[data-theme="rose"] {
    --t-body: #fff1f2;
    --t-card: #fff;
    --t-card-border: #fecdd3;
    --t-text: #4c0519;
    --t-text-muted: #9f1239;
    --t-sidebar: #881337;
    --t-sidebar-head: #4c0519;
    --t-sidebar-active: #fb7185;
    --t-topbar: linear-gradient(135deg, #881337, #9f1239);
    --t-topbar-text: #fff1f2;
    --t-input-bg: #fff1f2;
    --t-input-border: #fda4af;
    --t-accent: #f43f5e;
    --t-accent-light: #ffe4e6;
    --t-hover: #fff1f2;
}
/* ─── Gece Mavisi ─── */
[data-theme="midnight"] {
    --t-bg: #0f172a;
    --t-body: #0f172a;
    --t-card: #1e293b;
    --t-card-border: #334155;
    --t-text: #cbd5e1;
    --t-text-muted: #94a3b8;
    --t-sidebar: #0c4a6e;
    --t-sidebar-head: #082f49;
    --t-sidebar-active: #0ea5e9;
    --t-topbar: linear-gradient(135deg, #0c4a6e, #0369a1);
    --t-topbar-text: #e0f2fe;
    --t-input-bg: #0f172a;
    --t-input-border: #475569;
    --t-accent: #0ea5e9;
    --t-accent-light: #0c4a6e;
    --t-hover: #1e293b;
}

/* Masraf girişi özet şeridi — gece / gece mavisi okunabilirlik */
[data-theme="dark"],
[data-theme="midnight"] {
    --mg-strip-label: #94a3b8;
    --mg-strip-note: #94a3b8;
    --mg-val-not-arrived: #cbd5e1;
    --mg-val-arrived: #22d3ee;
    --mg-val-reported: #fb923c;
    --mg-val-debt: #f87171;
    --mg-val-paid: #4ade80;
    --mg-val-total: #c4b5fd;
    --mg-balance-box-bg: #334155;
    --mg-balance-value: #f8fafc;
    --mg-balance-positive: #4ade80;
    --mg-balance-negative: #fca5a5;
    --eg-cert-banner-bg: linear-gradient(135deg, color-mix(in srgb, #22c55e 20%, #1e293b), color-mix(in srgb, #22c55e 12%, #0f172a));
    --eg-cert-banner-border: color-mix(in srgb, #4ade80 45%, #334155);
    --eg-cert-banner-title: #bbf7d0;
    --eg-cert-banner-body: #94a3b8;
    --eg-warn-banner-bg: linear-gradient(135deg, color-mix(in srgb, #f59e0b 18%, #1e293b), color-mix(in srgb, #f59e0b 10%, #0f172a));
    --eg-warn-banner-border: color-mix(in srgb, #fbbf24 42%, #334155);
    --eg-warn-banner-title: #fde68a;
    --eg-warn-banner-body: #fcd34d;
}

/* ─── Safir ─── */
[data-theme="sapphire"] {
    --t-body: #eff6ff;
    --t-card: #fff;
    --t-card-border: #bfdbfe;
    --t-text: #1e3a5f;
    --t-text-muted: #3b82f6;
    --t-sidebar: #1e3a5f;
    --t-sidebar-head: #172554;
    --t-sidebar-active: #3b82f6;
    --t-topbar: linear-gradient(135deg, #1e3a5f, #1d4ed8);
    --t-topbar-text: #eff6ff;
    --t-input-bg: #f0f7ff;
    --t-input-border: #93c5fd;
    --t-accent: #2563eb;
    --t-accent-light: #dbeafe;
    --t-hover: #eff6ff;
}
/* ─── Kahve ─── */
[data-theme="mocha"] {
    --t-body: #faf6f1;
    --t-card: #fffcf8;
    --t-card-border: #e8ddd0;
    --t-text: #3e2723;
    --t-text-muted: #795548;
    --t-sidebar: #4e342e;
    --t-sidebar-head: #3e2723;
    --t-sidebar-active: #d4a373;
    --t-topbar: linear-gradient(135deg, #4e342e, #6d4c41);
    --t-topbar-text: #faf6f1;
    --t-input-bg: #fdf8f3;
    --t-input-border: #d7ccc8;
    --t-accent: #8d6e63;
    --t-accent-light: #efebe9;
    --t-hover: #f5f0eb;
}
/* ─── Kum ─── */
[data-theme="sand"] {
    --t-body: #fefce8;
    --t-card: #fffef5;
    --t-card-border: #fde68a;
    --t-text: #422006;
    --t-text-muted: #854d0e;
    --t-sidebar: #78350f;
    --t-sidebar-head: #451a03;
    --t-sidebar-active: #fbbf24;
    --t-topbar: linear-gradient(135deg, #78350f, #92400e);
    --t-topbar-text: #fefce8;
    --t-input-bg: #fefce8;
    --t-input-border: #fcd34d;
    --t-accent: #d97706;
    --t-accent-light: #fef3c7;
    --t-hover: #fefce8;
}
/* ─── Çelik ─── */
[data-theme="steel"] {
    --t-body: #f0f4f8;
    --t-card: #fff;
    --t-card-border: #d2d6dc;
    --t-text: #1f2933;
    --t-text-muted: #52606d;
    --t-sidebar: #323f4b;
    --t-sidebar-head: #1f2933;
    --t-sidebar-active: #3ebd93;
    --t-topbar: linear-gradient(135deg, #323f4b, #3e4c59);
    --t-topbar-text: #f0f4f8;
    --t-input-bg: #f5f7fa;
    --t-input-border: #cbd2d9;
    --t-accent: #3ebd93;
    --t-accent-light: #e6fffa;
    --t-hover: #f5f7fa;
}
/* ─── Nane ─── */
[data-theme="mint"] {
    --t-body: #f0fdfa;
    --t-card: #fff;
    --t-card-border: #99f6e4;
    --t-text: #134e4a;
    --t-text-muted: #0f766e;
    --t-sidebar: #115e59;
    --t-sidebar-head: #0f4c47;
    --t-sidebar-active: #2dd4bf;
    --t-topbar: linear-gradient(135deg, #115e59, #0f766e);
    --t-topbar-text: #f0fdfa;
    --t-input-bg: #f0fdfa;
    --t-input-border: #5eead4;
    --t-accent: #14b8a6;
    --t-accent-light: #ccfbf1;
    --t-hover: #f0fdfa;
}

/* Font boyutu — html root'a uygula, tüm rem birimleri otomatik ölçeklenir */
html[data-font="small"]  { font-size: 14px !important; }
html[data-font="large"]  { font-size: 18px !important; }

/* Personel fotoğrafı koruma — sağ tık indirme engeli */
.online-avatar,
.msg-avatar-img,
.bday-avatar-img,
.today-avatar-img,
.thread-avatar-img,
.profile-photo,
.photo-preview img,
.hk-avatar-img {
    -webkit-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    -webkit-touch-callout: none;
    pointer-events: auto;
}

/* Dashboard overlay açıkken scroll kilidi */
html.no-scroll .main-content {
    overflow: hidden !important;
}

/* Yazı tipi (font-family) */
html[data-font-family="inter"]      { font-family: 'Inter', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="roboto"]     { font-family: 'Roboto', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="poppins"]    { font-family: 'Poppins', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="nunito"]     { font-family: 'Nunito', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="ubuntu"]     { font-family: 'Ubuntu', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="lato"]       { font-family: 'Lato', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="opensans"]   { font-family: 'Open Sans', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="raleway"]    { font-family: 'Raleway', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="quicksand"]  { font-family: 'Quicksand', 'Noto Sans', 'Noto Sans Arabic', 'Segoe UI', system-ui, sans-serif !important; }
html[data-font-family="firacode"]   { font-family: 'Fira Code', 'Noto Sans', 'Noto Sans Arabic', 'Consolas', monospace !important; }
html[data-font-family="jetbrains"]  { font-family: 'JetBrains Mono', 'Noto Sans', 'Noto Sans Arabic', 'Consolas', monospace !important; }

html[data-font-family] body,
html[data-font-family] input,
html[data-font-family] select,
html[data-font-family] textarea,
html[data-font-family] button {
    font-family: inherit !important;
}

/* ═══ TEMA DEĞİŞKENLERİNİ UYGULA ═══ */
html[data-theme] {
    background: var(--t-body) !important;
}
/* Yönetim / login: html gövdesi seçilen temanın --t-body rengini kullanır (sabit gri/mavi sıfırlama yok) */
html[data-theme]:has(.ym-page),
html[data-theme]:has(.yonetim-wrapper),
html[data-theme]:has(.login-page) {
    background: var(--t-body) !important;
}
[data-theme] body {
    background: var(--t-body) !important;
    color: var(--t-text);
    transition: background 0.3s, color 0.3s;
}

/* Sidebar — tüm temalar dahil (light'ta data-theme yok, var fallback çalışır) */
.modern-sidebar          { background: var(--t-sidebar, #1e293b) !important; }
.sidebar-header          { background: var(--t-sidebar-head, #0f172a) !important; }
.sidebar-link.active     { background: var(--t-sidebar-active, #0ea5e9) !important; color: #fff !important; }
.sidebar-link            { color: rgba(255,255,255,0.8) !important; }
.sidebar-link.sidebar-admin-switch { color: #93c5fd !important; }
.sidebar-link.sidebar-admin-switch:hover { background: rgba(99,102,241,0.15) !important; color: #93c5fd !important; }
.sidebar-link:hover      { background: rgba(255,255,255,0.1) !important; color: #fff !important; }
.sidebar-footer          { border-top-color: rgba(255,255,255,0.1) !important; }
/* Çıkış butonu — her temada sabit kırmızı */
.sidebar-footer .logout-link,
.sidebar-link.logout-link { color: #fca5a5 !important; }
.sidebar-footer .logout-link:hover,
.sidebar-link.logout-link:hover { background: rgba(239,68,68,0.2) !important; color: #fecaca !important; }
.ku-drawer-exit { color: #dc2626 !important; }
.ku-drawer-exit:hover { background: #fef2f2 !important; color: #dc2626 !important; }
.mobile-pill { background: linear-gradient(135deg, var(--t-sidebar-active, #6366f1), color-mix(in srgb, var(--t-sidebar-active, #6366f1) 70%, #000 30%)) !important;
               box-shadow: 0 4px 16px color-mix(in srgb, var(--t-sidebar-active, #6366f1) 40%, transparent) !important; }

/* Topbar (kullanıcı sayfaları) */
[data-theme] .ku-topbar               { background: var(--t-topbar) !important; }
[data-theme] .ku-topbar h2            { color: var(--t-topbar-text) !important; }

/* ── Genel kartlar, formlar, kutular ── */
[data-theme] .form-section,
[data-theme] .settings-card,
[data-theme] .page-container .settings-card,
[data-theme] .setting-box .box-header {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .setting-box {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .box-header {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
    background: var(--t-card) !important;
}

/* ── Başlıklar ── */
[data-theme] .form-header h2,
[data-theme] .form-header h3,
[data-theme] h2, [data-theme] h3, [data-theme] h4 {
    color: var(--t-text);
}

/* ── Input, select, textarea ── */
[data-theme] .s-input, [data-theme] .m-input,
[data-theme] input[type="text"], [data-theme] input[type="date"], [data-theme] input[type="time"],
[data-theme] input[type="number"], [data-theme] input[type="email"], [data-theme] input[type="password"],
[data-theme] input[type="search"], [data-theme] input[type="tel"],
[data-theme] textarea, [data-theme] select {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
[data-theme] select option {
    background: var(--t-card);
    color: var(--t-text);
}

/* ── Tema select — hover/focus + koyu tema ok rengi ── */
[data-theme] select {
    background-color: var(--t-input-bg) !important;
    transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
}
[data-theme] select:hover {
    border-color: var(--t-accent, #6366f1) !important;
    background-color: var(--t-hover) !important;
}
[data-theme] select:focus {
    border-color: var(--t-accent, #6366f1) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-accent, #6366f1) 12%, transparent);
    outline: none;
}
/* Koyu temalarda ok rengini açık yap */
[data-theme="dark"] select,
[data-theme="midnight"] select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2394a3b8' d='M5 6L0 0h10z'/%3E%3C/svg%3E") !important;
}

/* ── Label ── */
[data-theme] label, [data-theme] .group label, [data-theme] .s-field label {
    color: var(--t-text-muted) !important;
}

/* ── Tablolar ── */
[data-theme] .modern-table, [data-theme] table {
    color: var(--t-text);
}
[data-theme] .modern-table th, [data-theme] table th,
[data-theme] .table-responsive thead th {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .modern-table td, [data-theme] table td {
    border-color: var(--t-card-border) !important;
    color: var(--t-text);
}
[data-theme] .modern-table tr:hover, [data-theme] table tbody tr:hover {
    background: var(--t-hover) !important;
}
/* Sticky thead tema uyumu */
[data-theme] .table-responsive thead th,
[data-theme] .ekm-table-wrap thead th,
[data-theme] .izn-table-wrap thead th {
    background: var(--t-hover) !important;
}

/* ── Butonlar — primary gradient tema accent kullanacak ── */
[data-theme] .s-btn.primary {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 70%, #000 30%)) !important;
}

/* ── Genel metin renkleri ── */
[data-theme] .box-desc, [data-theme] .field-hint, [data-theme] .card-desc {
    color: var(--t-text-muted) !important;
}

/* ── Kullanıcı topbar dropdown ── */
[data-theme] .ym-topbar-dropdown {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-td-item {
    color: var(--t-text) !important;
}
[data-theme] .ym-td-item:hover {
    background: var(--t-hover) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ym-td-item.ym-td-exit {
    color: #dc2626 !important;
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .ym-td-item.ym-td-exit:hover {
    background: #fef2f2 !important;
    color: #b91c1c !important;
}

/* ── Mobil drawer ── */
[data-theme] .ku-drawer {
    background: var(--t-card) !important;
}
[data-theme] .ku-drawer-header {
    background: var(--t-topbar) !important;
}
[data-theme] .ku-drawer-title {
    color: white !important;
}
[data-theme] .ku-drawer-close {
    color: white !important;
}
[data-theme] .ku-drawer-link {
    color: var(--t-text) !important;
}
[data-theme] .ku-drawer-link:hover {
    background: var(--t-hover) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ku-drawer-link.active {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .ku-drawer-footer {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .ku-drawer-footer .ku-drawer-link {
    color: var(--t-accent) !important;
}
[data-theme] .ku-drawer-footer .ku-drawer-link.ku-drawer-home {
    color: var(--t-text) !important;
}
[data-theme] .ku-drawer-footer .ku-drawer-link.ku-drawer-exit {
    color: #dc2626 !important;
}
[data-theme] .ku-drawer-footer .ku-drawer-link.ku-drawer-exit:hover {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
[data-theme] .ku-drawer-admin {
    color: var(--t-accent) !important;
}
[data-theme] .ku-drawer-nav {
    background: var(--t-card) !important;
}

/* ── Sayfa container'ları ── */
[data-theme] .page-container {
    color: var(--t-text);
}

/* ── Contact, info kutuları ── */
[data-theme] .contact-row {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Dark tema özel düzeltmeler ── */
[data-theme] .form-header { border-left-color: var(--t-accent) !important; }
[data-theme="dark"] .form-section { box-shadow: 0 2px 8px rgba(0,0,0,0.3) !important; }
/* reconnect tema stili → ReconnectModal.razor.css */

/* ═══════════════════════════════════════════════════════
   KAPSAMLI TEMA — Scoped CSS override (tüm sayfalar)
   Scoped CSS [b-xxx] attribute specificity'yi !important ezer.
   Sadece data-theme varken aktif (light varsayılan dokunmaz).
   ═══════════════════════════════════════════════════════ */

/* ── Tüm beyaz arka planlı paneller, kartlar, kutular ── */
[data-theme] .form-section,
[data-theme] .settings-card,
[data-theme] .filter-bar,
[data-theme] .dt-card,
[data-theme] .dt-layout,
[data-theme] .dt-new-form,
[data-theme] .dt-btn-cancel,
[data-theme] .dt-btn-close,
[data-theme] .msg-item,
[data-theme] .msg-layout,
[data-theme] .thread-msg,
[data-theme] .izn-bakiye-card,
[data-theme] .izn-grp,
[data-theme] .izn-talep-section,
[data-theme] .izn-liste-section,
[data-theme] .izn-hakedis-section,
[data-theme] .ekm-stat,
[data-theme] .ekm-card,
[data-theme] .sinav-intro,
[data-theme] .video-item,
[data-theme] .sik-item,
[data-theme] .sonuc-panel,
[data-theme] .detay-table,
[data-theme] .progress-step,
[data-theme] .progress-strip,
[data-theme] .gecmis-table,
[data-theme] .quick-msg-panel,
[data-theme] .notif-popup,
[data-theme] .balance-strip,
[data-theme] .avans-section,
[data-theme] .odenen-panel,
[data-theme] .section-card,
[data-theme] .bday-section,
[data-theme] .profile-card,
[data-theme] .detail-section,
[data-theme] .cert-body,
[data-theme] .menu-card,
[data-theme] .user-dropdown,
[data-theme] .online-panel,
[data-theme] .table-responsive,
[data-theme] .chip-check,
[data-theme] .cancel-btn,
[data-theme] .recall-no,
[data-theme] .col-filter-banner button,
[data-theme] .cfp-dropdown,
[data-theme] .msg-quick-btn,
[data-theme] .photo-edit-btn,
[data-theme] .msg-sidebar,
[data-theme] .msg-sidebar-header,
[data-theme] .msg-tabs,
[data-theme] .msg-tab,
[data-theme] .compose-area,
[data-theme] .dt-list,
[data-theme] .dt-detail-card,
[data-theme] .dt-back-btn,
[data-theme] .dt-input,
[data-theme] .dt-search input,
[data-theme] .dt-detail,
[data-theme] .dt-field label,
[data-theme] .bday-row,
[data-theme] .forgot-card {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Border override'ları (kenar çizgileri) ── */
[data-theme] .msg-sidebar {
    border-right-color: var(--t-card-border) !important;
}
[data-theme] .msg-tabs {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .msg-sidebar-header {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .msg-item {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .msg-tab.active {
    color: var(--t-accent) !important;
    border-bottom-color: var(--t-accent) !important;
}
[data-theme] .dt-list {
    background: var(--t-hover) !important;
    border-right-color: var(--t-card-border) !important;
}
[data-theme] .dt-card {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .dt-card.selected {
    background: var(--t-accent-light) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .msg-item.selected {
    background: var(--t-accent-light) !important;
    border-left-color: var(--t-accent) !important;
}

/* ── Tablo arkaplanları ── */
[data-theme] .modern-table,
[data-theme] .ekm-table,
[data-theme] .izn-tablo,
[data-theme] .izin-table,
[data-theme] .odenen-table,
[data-theme] .gecmis-table,
[data-theme] table {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}
[data-theme] .modern-table th,
[data-theme] .ekm-table th,
[data-theme] .ekm-table thead,
[data-theme] .ekm-tabs,
[data-theme] .izn-tablo th,
[data-theme] .izin-table th,
[data-theme] .odenen-table th,
[data-theme] .gecmis-table th,
[data-theme] .detay-table th,
[data-theme] table thead th {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .modern-table td,
[data-theme] .ekm-table td,
[data-theme] .izn-tablo td,
[data-theme] .izin-table td,
[data-theme] .odenen-table td,
[data-theme] .gecmis-table td,
[data-theme] .detay-table td,
[data-theme] table td {
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .modern-table tbody tr:hover,
[data-theme] .ekm-table tbody tr:hover,
[data-theme] .izn-tablo tbody tr:hover,
[data-theme] .izin-table tbody tr:hover,
[data-theme] .odenen-table tr:hover td,
[data-theme] table tbody tr:hover {
    background: var(--t-hover) !important;
}

/* ── Hover & header #f8fafc alanları ── */
[data-theme] .detail-header,
[data-theme] .thread-header,
[data-theme] .filter-bar,
[data-theme] .info-card,
[data-theme] .izin-bakiye-mini,
[data-theme] .izin-ozet,
[data-theme] .izn-hakedis-item,
[data-theme] .izn-talep-header,
[data-theme] .izn-liste-header,
[data-theme] .soru-metni,
[data-theme] .timer-bar,
[data-theme] .note-text,
[data-theme] .setting-box,
[data-theme] .mobile-back-btn {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .dt-card:hover,
[data-theme] .msg-item:hover,
[data-theme] .bday-row:hover,
[data-theme] .avans-header:hover,
[data-theme] .cfp-item:hover,
[data-theme] .video-item:hover,
[data-theme] .msg-tab:hover,
[data-theme] .tab-btn:hover,
[data-theme] .recall-no:hover,
[data-theme] .cancel-btn:hover {
    background: var(--t-hover) !important;
}
[data-theme] .tab-btn.active {
    color: var(--t-accent) !important;
    border-bottom-color: var(--t-accent) !important;
    background: linear-gradient(to bottom, var(--t-accent-light), transparent) !important;
}
[data-theme] .msg-tab.active {
    color: var(--t-accent) !important;
    border-bottom-color: var(--t-accent) !important;
}

/* ── Başlık barları (title-with-icon, form-header, list-header, box-header) ── */
[data-theme] .title-with-icon,
[data-theme] .form-header,
[data-theme] .box-header {
    color: var(--t-text) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .title-with-icon h2,
[data-theme] .title-with-icon h3,
[data-theme] .form-header h2,
[data-theme] .form-header h3 {
    color: var(--t-text) !important;
}

/* ── Koyu topbar tarzı list-header (tablo üst barı) ── */
[data-theme] .list-header {
    background: var(--t-topbar) !important;
    color: var(--t-topbar-text, #fff) !important;
}
[data-theme] .list-header h2,
[data-theme] .list-header h3 {
    color: var(--t-topbar-text, #fff) !important;
}
[data-theme] .count-badge {
    background: var(--t-accent) !important;
    color: #fff !important;
}

/* ── Butonlar ── */
[data-theme] .btn-save,
[data-theme] .btn-new,
[data-theme] .dt-new-btn,
[data-theme] .dt-btn-send,
[data-theme] .compose-btn,
[data-theme] .send-btn,
[data-theme] .qm-send,
[data-theme] .avans-btn {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 75%, #000)) !important;
    color: #fff !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .btn-delete {
    background: linear-gradient(135deg, #dc2626, #ef4444) !important;
    color: #fff !important;
}
[data-theme] .filter-btn,
[data-theme] .dt-filter,
[data-theme] .btn-soru-nav {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .filter-btn:hover,
[data-theme] .dt-filter:hover,
[data-theme] .filter-btn.active,
[data-theme] .dt-filter.active {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}

/* ── Pill / Badge'ler ── */
[data-theme] .status-pill,
[data-theme] .yetki-pill,
[data-theme] .ekm-pill,
[data-theme] .izn-durum-pill,
[data-theme] .izn-tur-pill,
[data-theme] .avans-durum-pill,
[data-theme] .dt-tur-tag,
[data-theme] .sonuc-pill {
    border-color: var(--t-card-border) !important;
}

/* ── Input, select, textarea ── */
[data-theme] .field-input,
[data-theme] input[type="text"],
[data-theme] input[type="date"],
[data-theme] input[type="time"],
[data-theme] input[type="number"],
[data-theme] input[type="email"],
[data-theme] input[type="password"],
[data-theme] input[type="search"],
[data-theme] input[type="tel"],
[data-theme] textarea,
[data-theme] select {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
/* (koyu container input override'ları CSS sonuna taşındı) */
[data-theme] select option {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

/* ── Label & metin ── */
[data-theme] label,
[data-theme] .group label {
    color: var(--t-text-muted) !important;
}
[data-theme] .form-message {
    border-color: var(--t-card-border) !important;
}

/* ── Hardcoded text renkleri → tema uyumu ── */
[data-theme] .avans-title,
[data-theme] .avans-tutar,
[data-theme] .bday-name,
[data-theme] .card-header,
[data-theme] .cfp-title,
[data-theme] .dt-card-konu,
[data-theme] .d-value,
[data-theme] .ekm-stat-num,
[data-theme] .field-input,
[data-theme] .izn-bk-val,
[data-theme] .msg-from,
[data-theme] .readonly-val,
[data-theme] .section-header,
[data-theme] .td-device,
[data-theme] .td-id,
[data-theme] .timer-text,
[data-theme] .video-title,
[data-theme] .detail-body,
[data-theme] .detail-parties,
[data-theme] .dt-bubble-text,
[data-theme] .sonuc-info,
[data-theme] .sik-text,
[data-theme] .cert-text,
[data-theme] .cert-mini-info,
[data-theme] .code-tag,
[data-theme] .patient-tag,
[data-theme] .remember-text {
    color: var(--t-text) !important;
}
[data-theme] .ekm-empty,
[data-theme] .ekm-no-result,
[data-theme] .ekm-body,
[data-theme] .ekm-header,
[data-theme] .ekm-sert-info,
[data-theme] .dt-detail-header h3,
[data-theme] .bday-header h2,
[data-theme] .bday-list h3,
[data-theme] .msg-sidebar-header h3,
[data-theme] .dt-new-form h3,
[data-theme] .izn-talep-header h2,
[data-theme] .izn-hakedis-section h3 {
    color: var(--t-text) !important;
}
[data-theme] .ekm-stat-lbl,
[data-theme] .ekm-model,
[data-theme] .ekm-count,
[data-theme] .ekm-no-cert {
    color: var(--t-text-muted) !important;
}
[data-theme] .ekm-card {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-stat {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-stat.green {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .ekm-stat.orange {
    background: color-mix(in srgb, var(--t-accent-light) 70%, var(--t-hover) 30%) !important;
    border-color: color-mix(in srgb, var(--t-accent) 60%, var(--t-card-border) 40%) !important;
}
[data-theme] .ekm-stat.purple {
    background: color-mix(in srgb, var(--t-accent-light) 50%, var(--t-hover) 50%) !important;
    border-color: color-mix(in srgb, var(--t-accent) 40%, var(--t-card-border) 60%) !important;
}
[data-theme] .ekm-stat.active {
    box-shadow: 0 0 0 2px var(--t-accent), 0 4px 12px rgba(0,0,0,0.1) !important;
}
[data-theme] .ekm-stat-num {
    color: var(--t-text) !important;
}
[data-theme] .ekm-stat.green .ekm-stat-num {
    color: var(--t-accent) !important;
}
[data-theme] .ekm-stat.orange .ekm-stat-num {
    color: color-mix(in srgb, var(--t-accent) 80%, var(--t-text) 20%) !important;
}
[data-theme] .ekm-stat.purple .ekm-stat-num {
    color: color-mix(in srgb, var(--t-accent) 60%, var(--t-text) 40%) !important;
}
[data-theme] .ekm-stat-lbl {
    color: var(--t-text-muted) !important;
}
[data-theme] .ekm-tab {
    background: var(--t-card) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-tab.active {
    background: var(--t-card) !important;
    color: var(--t-accent) !important;
    border-bottom-color: var(--t-accent) !important;
}
[data-theme] .ekm-tab-badge {
    background: var(--t-accent) !important;
    color: #fff !important;
}
[data-theme] .ekm-tabs {
    border-bottom-color: var(--t-card-border) !important;
    background: var(--t-hover) !important;
}
[data-theme] .ekm-count {
    color: var(--t-text-muted) !important;
}

/* Ekipmanlarım — aydınlık temada özet kartlarının pastel renkleri (global tema mix'ini geçersiz kılar) */
[data-theme="light"] .ekm-stat:not(.green):not(.orange):not(.purple) {
    background: #f8fafc !important;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .ekm-stat.green {
    background: #f0fdf4 !important;
    border-color: #bbf7d0 !important;
}
[data-theme="light"] .ekm-stat.orange {
    background: #fff7ed !important;
    border-color: #fed7aa !important;
}
[data-theme="light"] .ekm-stat.purple {
    background: #faf5ff !important;
    border-color: #e9d5ff !important;
}
[data-theme="light"] .ekm-stat-num {
    color: #1e293b !important;
}
[data-theme="light"] .ekm-stat.green .ekm-stat-num {
    color: #16a34a !important;
}
[data-theme="light"] .ekm-stat.orange .ekm-stat-num {
    color: #d97706 !important;
}
[data-theme="light"] .ekm-stat.purple .ekm-stat-num {
    color: #7c3aed !important;
}
[data-theme="light"] .ekm-tabs {
    background: #f8fafc !important;
    border-bottom-color: #e2e8f0 !important;
}
[data-theme="light"] .ekm-tab {
    background: transparent !important;
}
[data-theme="light"] .ekm-tab.active {
    background: transparent !important;
}

/* ── Muted metin renkleri (#64748b, #94a3b8) ── */
[data-theme] .avans-card-desc,
[data-theme] .bday-day,
[data-theme] .izin-bm-item,
[data-theme] .cfp-item,
[data-theme] .contact-row,
[data-theme] .bday-birim,
[data-theme] .bday-age-small,
[data-theme] .dt-header-sub,
[data-theme] .dt-card-date,
[data-theme] .dt-detail-date,
[data-theme] .msg-tab,
[data-theme] .izn-bk-label,
[data-theme] .izn-hk-ack,
[data-theme] .countdown-days {
    color: var(--t-text-muted) !important;
}
[data-theme] .countdown-days {
    background: var(--t-hover) !important;
}
[data-theme] .ekm-search-wrap input {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}

/* ── Ekipman sertifika header ve empty ── */
[data-theme] .ekm-sert-header {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-sert-info strong {
    color: var(--t-text) !important;
}
[data-theme] .ekm-sert-info span {
    color: var(--t-text-muted) !important;
}
[data-theme] .ekm-sert-total {
    color: var(--t-accent) !important;
}
[data-theme] .ekm-empty {
    color: var(--t-text-muted) !important;
}
[data-theme] .ekm-empty h3 {
    color: var(--t-text) !important;
}
[data-theme] .ekm-empty p {
    color: var(--t-text-muted) !important;
}
/* Ekipman boş durum kartı — scoped tasarımın koyu temada okunabilir kalması */
[data-theme] .ekm-empty-state {
    background: linear-gradient(180deg, var(--t-hover) 0%, var(--t-card) 48%) !important;
    border-color: var(--t-card-border) !important;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08) !important;
}
[data-theme] .ekm-empty-state .ekm-empty-ico {
    background: linear-gradient(145deg, var(--t-accent-light), color-mix(in srgb, var(--t-hover) 55%, var(--t-accent-light))) !important;
    border-color: color-mix(in srgb, var(--t-accent) 40%, var(--t-card-border)) !important;
    box-shadow: 0 6px 16px color-mix(in srgb, var(--t-accent) 15%, transparent) !important;
}
[data-theme] .ekm-empty-state--muted .ekm-empty-ico {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.06) !important;
}
[data-theme] .ekm-no-result {
    color: var(--t-text-muted) !important;
}
[data-theme] .td-dosya {
    color: var(--t-accent) !important;
}
[data-theme] .m-input:disabled {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* ── Sayfa arka planı (.page-container wrapper'lar) ── */
[data-theme] .page-container {
    background: transparent !important;
}

/* ── Topbar kullanıcı butonu ── */
[data-theme] .ym-topbar-ubtn {
    border-color: rgba(255,255,255,0.2) !important;
}

/* ═══════════════════════════════════════════════════════════════
   YÖNETİM DASHBOARD — KULLANICI MENÜSÜ (YonetimTopbarUserMenu)
   Alt bileşen DOM'u parent'ın scoped CSS attribute'unu almaz;
   bu yüzden bu stiller global olarak burada tanımlı.
   ═══════════════════════════════════════════════════════════════ */
.ym-user-menu-wrap { position: relative; }
.ym-user-btn {
    padding: 0 14px; border-radius: 10px; border: 1.5px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08); color: #e2e8f0; font-weight: 600;
    font-size: 0.88rem; cursor: pointer; transition: background 0.2s, border-color 0.2s;
    display: flex; align-items: center; gap: 10px;
    height: 40px; min-height: 40px; max-height: 40px; line-height: 1;
    box-sizing: border-box; position: relative; overflow: visible;
}
.ym-user-btn:hover { background: rgba(255,255,255,0.14); border-color: rgba(255,255,255,0.32); }
.ym-user-btn .ym-user-ico { font-size: 0.95rem; line-height: 1; flex-shrink: 0; }
.ym-user-btn .ku-user-stack {
    display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
    min-width: 0; gap: 0; line-height: 1.1;
}
.ym-user-btn .ym-user-name {
    font-weight: 600; font-size: 0.82rem; max-width: 14rem;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    line-height: 1.15;
}
.ym-user-btn .ku-presence-inline {
    display: inline-flex; align-items: center; gap: 5px; margin-top: 2px;
    font-size: 0.66rem; font-weight: 600; letter-spacing: 0.02em;
    color: rgba(226, 232, 240, 0.82); max-width: 14rem;
}
.ym-user-btn .ku-presence-inline-label {
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ym-user-btn .ku-presence-inline-dot {
    width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.ym-user-btn .ku-presence-inline-musait .ku-presence-inline-dot { background: #4ade80; }
.ym-user-btn .ku-presence-inline-mesgul .ku-presence-inline-dot { background: #fbbf24; }
.ym-user-btn .ku-presence-inline-rahatsiz_etme .ku-presence-inline-dot { background: #f87171; }
.ym-user-btn .ku-presence-inline-gorunmez .ku-presence-inline-dot { background: #94a3b8; }
.ym-user-btn .ym-arrow.topbar-user-chevron-wrap {
    margin-left: 0; font-size: 0.58rem;
    color: rgba(226, 232, 240, 0.55); line-height: 1; width: 1em; text-align: center;
    font-family: system-ui, sans-serif;
}
.ym-user-btn .ym-arrow.topbar-user-chevron-wrap .topbar-user-chevron { display: none; }
@media (max-width: 520px) {
    .ym-user-btn .ku-presence-inline-label { display: none; }
}
@media (max-width: 768px) {
    .ym-user-btn .ku-user-stack { display: none; }
    .ym-user-btn .topbar-user-chevron-wrap { display: none; }
}
/* Mobilde dashboard topbar kullanıcı butonu diğer 34px öğelerle (online status, notif-btn) piksel-perfect eşit olsun */
@media (max-width: 600px) {
    .ym-header .ym-user-btn,
    .ym-header-right .ym-user-btn {
        height: 34px !important;
        min-height: 34px !important;
        max-height: 34px !important;
        padding: 0 10px !important;
        border-width: 1px !important;
        border-radius: 8px !important;
        font-size: 0.78rem !important;
        line-height: 1 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        white-space: nowrap !important;
    }
    .ym-header .ym-user-btn .ku-user-stack,
    .ym-header-right .ym-user-btn .ku-user-stack,
    .ym-header .ym-user-btn .topbar-user-chevron-wrap,
    .ym-header-right .ym-user-btn .topbar-user-chevron-wrap {
        display: none !important;
    }
}

/* Açık/renkli temalarda buton için topbar-text kontrastı */
[data-theme]:not([data-theme="dark"]):not([data-theme="midnight"]) .ym-user-btn {
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(255,255,255,0.2) !important;
    color: var(--t-topbar-text, #fff) !important;
}
[data-theme]:not([data-theme="dark"]):not([data-theme="midnight"]) .ym-user-btn:hover {
    background: rgba(255,255,255,0.14) !important;
    border-color: rgba(255,255,255,0.35) !important;
}
[data-theme]:not([data-theme="dark"]):not([data-theme="midnight"]) .ym-user-btn .ku-presence-inline {
    color: color-mix(in srgb, var(--t-topbar-text, #fff) 82%, transparent) !important;
}

.ym-user-dropdown {
    position: absolute; top: calc(100% + 6px); right: 0; min-width: 220px;
    background: #ffffff; border-radius: 12px; box-shadow: 0 12px 40px rgba(0,0,0,0.3);
    border: 1px solid #e2e8f0; z-index: 2000; overflow: hidden;
    animation: ymDropSlide 0.2s ease;
}
@keyframes ymDropSlide { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }
.ym-user-dropdown .ym-presence-in-dropdown {
    padding: 12px 12px 14px;
    border-bottom: 1px solid var(--t-card-border, #e2e8f0);
    background: linear-gradient(180deg, var(--t-hover, #f8fafc) 0%, var(--t-card, #fff) 100%);
}
.ym-arrow.topbar-user-chevron-wrap:not(.topbar-user-chevron-wrap--neutral) { margin-left: 2px; }

.ym-user-dropdown .ym-td-item,
.ym-user-dropdown .ym-ud-item {
    display: flex; align-items: center; gap: 10px; width: 100%; padding: 12px 18px;
    border: none; background: none; cursor: pointer; font-size: 0.88rem; font-weight: 600;
    color: #334155; transition: all 0.15s; text-align: left;
}
.ym-user-dropdown .ym-td-item:hover,
.ym-user-dropdown .ym-ud-item:hover { background: #f0f9ff; color: #0369a1; }
.ym-user-dropdown .ym-ud-item.ym-ud-exit { color: #dc2626; border-top: 1px solid #f1f5f9; }
.ym-user-dropdown .ym-ud-item.ym-ud-exit:hover { background: #fef2f2; color: #b91c1c; }

/* Tema uyum — dropdown */
[data-theme] .ym-user-dropdown {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .ym-user-dropdown .ym-td-item,
[data-theme] .ym-user-dropdown .ym-ud-item {
    color: var(--t-text) !important;
}
[data-theme] .ym-user-dropdown .ym-td-item:hover,
[data-theme] .ym-user-dropdown .ym-ud-item:hover {
    background: var(--t-hover) !important;
    color: var(--t-accent) !important;
}

/* ── Form actions alanı ── */
[data-theme] .form-actions {
    border-top-color: var(--t-card-border) !important;
}

/* ── Tablo sıralama/filtre başlıkları ── */
[data-theme] .th-sf {
    color: var(--t-text) !important;
}

/* ── Footer ticker ── */
[data-theme] .footer-ticker {
    background: var(--t-card) !important;
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .ticker-text {
    color: var(--t-text-muted) !important;
}

/* ── Avans/Ödeme action butonları ── */
[data-theme] .avans-action-btn {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .avans-action-btn:hover {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}

/* ── Accent-light hover/active state'ler (#f0f9ff, #eef2ff) ── */
[data-theme] .sabit-veri-box,
[data-theme] .col-filter-banner,
[data-theme] .address-num,
[data-theme] .izin-tur,
[data-theme] .avans-aktif-badge,
[data-theme] .avans-istinaden-box,
[data-theme] .row-active,
[data-theme] .reply-btn,
[data-theme] .add-btn {
    background: var(--t-accent-light) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-tab:hover {
    background: var(--t-hover) !important;
    color: var(--t-accent) !important;
}
[data-theme] .mobile-back-btn:hover,
[data-theme] .msg-quick-btn:hover,
[data-theme] .online-user-row:hover,
[data-theme] .photo-edit-btn:hover,
[data-theme] .sik-item:hover,
[data-theme] .ud-item:hover,
[data-theme] .cfp-sort-btn:hover {
    background: var(--t-accent-light) !important;
}
[data-theme] .sabit-label {
    color: var(--t-accent) !important;
}

/* ── Kolon filtre paneli ── */
[data-theme] .cfp-backdrop {
    background: rgba(0,0,0,0.3) !important;
}
[data-theme] .cfp-dropdown {
    background: var(--t-card) !important;
    box-shadow: 0 25px 60px rgba(0,0,0,0.35) !important;
}
[data-theme] .cfp-sort-btn {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .cfp-sort-btn:hover,
[data-theme] .cfp-sort-btn.active {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .cfp-actions button {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Scroll-to-top butonu ── */
[data-theme] .scroll-top-btn {
    background: var(--t-sidebar) !important;
    color: #fff !important;
}

/* reconnect tema stili → ReconnectModal.razor.css */

/* ── SearchSelect dropdown tema ── */
[data-theme] .ss-panel {
    background: var(--t-card) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .ss-item {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .ss-item:hover {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ss-sel {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ss-empty {
    color: var(--t-text-muted) !important;
}
[data-theme] .ss-hl {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ss-match {
    background: rgba(250,204,21,0.25) !important;
}
[data-theme] .ss-clear {
    color: var(--t-text-muted) !important;
}
[data-theme] .ss-clear:hover {
    background: rgba(239,68,68,0.15) !important;
    color: #ef4444 !important;
}

/* ── Compose/Yeni mesaj alanı ── */
[data-theme] .compose-area {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .compose-area textarea,
[data-theme] .compose-area input {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}

/* ── Profil banner: .banner-gradient yalnızca Hakkımda'da; nokta örtüsü scoped CSS'te —
     global gradient ile ezilmesin diye burada kural yok. ── */

/* ── Masraf form grid içindeki group label ── */
[data-theme] .form-grid label,
[data-theme] .dt-field label,
[data-theme] .izn-grp label,
[data-theme] .field-group label {
    color: var(--t-text-muted) !important;
}

/* ── Disabled input'lar ── */
[data-theme] input:disabled,
[data-theme] select:disabled,
[data-theme] textarea:disabled {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

/* ── DataTaleplerim thread/detail panelleri ── */
[data-theme] .dt-detail {
    background: var(--t-card) !important;
}
[data-theme] .dt-bubble-text {
    color: var(--t-text) !important;
}

/* ── Destek empty/placeholder ── */
[data-theme] .dt-empty {
    color: var(--t-text-muted) !important;
}
[data-theme] .dt-placeholder {
    color: var(--t-text-muted) !important;
}
[data-theme] .dt-closed-info {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .dt-closed-info span {
    color: var(--t-text-muted) !important;
}

[data-theme] .dt-reply-area {
    background: var(--t-card) !important;
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .dt-reply-area textarea {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}

/* ── Eğitim sınav/video progress barları — sadece arka plan ── */
[data-theme] .soru-progress {
    background: var(--t-hover) !important;
}

/* ── Eğitimler — butonlar ── */
[data-theme] .btn-sinav-baslat,
[data-theme] .btn-sinava-gec,
[data-theme] .btn-sonraki-video {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 75%, #000)) !important;
    color: #fff !important;
}
/* Yeşil butonlar (sertifika, bitir) — tema accent rengine bağla */
[data-theme] .btn-sinav-bitir,
[data-theme] .btn-sertifika-git {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 70%, #000 30%)) !important;
    color: #fff !important;
}

/* ── Sınav intro ── */
[data-theme] .sinav-intro h3 {
    color: var(--t-text) !important;
}
[data-theme] .sinav-intro li {
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .sinav-intro ul {
    color: var(--t-text) !important;
}

/* ── Sınav şıkları ── */
[data-theme] .sik-item {
    border-color: var(--t-card-border) !important;
    background: var(--t-card) !important;
}
[data-theme] .sik-item:hover {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .sik-item.selected {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .sik-harf {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .sik-item.selected .sik-harf {
    background: var(--t-accent) !important;
    color: #fff !important;
}
[data-theme] .sik-text {
    color: var(--t-text) !important;
}

/* ── Soru metni kutusu ── */
[data-theme] .soru-metni {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .soru-no {
    color: var(--t-accent) !important;
}
[data-theme] .soru-progress-bar {
    background: var(--t-hover) !important;
}

/* ── Soru navigasyon ── */
[data-theme] .btn-soru-nav.next {
    background: var(--t-accent) !important;
    color: #fff !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .btn-soru-nav:hover {
    border-color: var(--t-accent) !important;
    color: var(--t-accent) !important;
}

/* ── Section header ── */
[data-theme] .section-header {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .header-badge {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}

/* ── Video listesi ── */
[data-theme] .v-num {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .video-desc,
[data-theme] .video-dur {
    color: var(--t-text-muted) !important;
}
[data-theme] .video-item.playing {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .video-progress-bar {
    background: var(--t-hover) !important;
}

/* ── Video player ── */
[data-theme] .video-player {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .video-player h3 {
    color: var(--t-text) !important;
}

/* ── İzleme progress ── */
[data-theme] .watch-progress-bar {
    background: var(--t-hover) !important;
}
[data-theme] .watch-progress-text {
    color: var(--t-text-muted) !important;
}

/* ── Timer bar ── */
[data-theme] .timer-bar {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .timer-progress {
    background: var(--t-hover) !important;
}

/* ── Progress strip inactive elemanlar ── */
[data-theme] .progress-step .step-num {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .progress-step .step-text {
    color: var(--t-text-muted) !important;
}
[data-theme] .progress-line {
    background: var(--t-hover) !important;
}
/* Active/done step'ler — tema accent rengi */
[data-theme] .progress-step.done .step-num {
    background: var(--t-accent) !important;
    color: #fff !important;
}
[data-theme] .progress-step.done .step-text {
    color: var(--t-accent) !important;
}
[data-theme] .progress-step.active .step-num {
    background: var(--t-accent) !important;
    color: #fff !important;
}
[data-theme] .progress-step.active .step-text {
    color: var(--t-accent) !important;
}
[data-theme] .progress-line.done {
    background: var(--t-accent) !important;
}

/* ── Geçmiş tablo ── */
[data-theme] .gecmis-table th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .gecmis-table td {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Sertifika popup ── */
[data-theme] .cert-detail-item strong {
    color: var(--t-text) !important;
}
[data-theme] .cert-label {
    color: var(--t-text-muted) !important;
}
[data-theme] .cert-sign span {
    color: var(--t-text-muted) !important;
}

/* ── Sonuç panel metinleri ── */
[data-theme] .sonuc-info {
    color: var(--t-text) !important;
}
[data-theme] .puan-max {
    color: var(--t-text-muted) !important;
}

/* ── Ekipman teslim/sertifika butonları ── */
[data-theme] .ekm-cert-btn {
    background: linear-gradient(135deg, var(--t-accent), var(--t-sidebar-active)) !important;
    color: #fff !important;
    border: none !important;
}
[data-theme] .ekm-teslim-btn {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ekm-teslim-btn:hover {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
    color: var(--t-accent) !important;
}

/* ── Yetkilendirme detay ── */
[data-theme] .detail-body {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

/* ── Mesaj kutusu thread detay ── */
[data-theme] .thread-header {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .thread-msg {
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Mesaj kutusu butonları ── */
[data-theme] .reply-btn {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .reply-btn:hover {
    background: color-mix(in srgb, var(--t-accent-light) 80%, var(--t-accent) 20%) !important;
}

/* ── Thread gelen mesaj balonu ── */
[data-theme] .thread-msg.received .thread-bubble {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
/* Giden mesaj balonu tema accent */
[data-theme] .thread-msg.sent .thread-bubble {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 75%, #000)) !important;
    color: #fff !important;
}

/* ── Thread section border ── */
[data-theme] .thread-section {
    border-top-color: var(--t-card-border) !important;
}

/* ── Mesaj kutusu başlıklar ── */
[data-theme] .compose-area h3 {
    color: var(--t-text) !important;
}
[data-theme] .compose-field label {
    color: var(--t-text-muted) !important;
}
[data-theme] .detail-header h3 {
    color: var(--t-text) !important;
}
[data-theme] .detail-date {
    color: var(--t-text-muted) !important;
}
[data-theme] .detail-parties {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .detail-actions {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .msg-placeholder {
    color: var(--t-text-muted) !important;
}
[data-theme] .msg-empty {
    color: var(--t-text-muted) !important;
}
[data-theme] .msg-subject {
    color: var(--t-text-muted) !important;
}
[data-theme] .msg-date {
    color: var(--t-text-muted) !important;
}

/* ── Read status pill'ler ── */
[data-theme] .read-status.read,
[data-theme] .detail-read-status.read {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .read-status.unread-status,
[data-theme] .detail-read-status.unread-status {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* ── Recall (geri çekme) ── */
[data-theme] .recall-btn {
    border-color: #f59e0b !important;
}
[data-theme] .recall-confirm {
    background: var(--t-hover) !important;
    border-color: #f59e0b !important;
}
[data-theme] .recall-confirm span {
    color: var(--t-text) !important;
}

/* ── Unread mesaj arka plan ── */
[data-theme] .msg-item.unread {
    background: color-mix(in srgb, var(--t-accent-light) 50%, var(--t-card) 50%) !important;
}

/* ── Mobile back button ── */
[data-theme] .mobile-back-btn {
    color: var(--t-accent) !important;
}

/* ── Avatar / baş harf daireleri (tüm sayfalar) ── */
[data-theme] .msg-avatar,
[data-theme] .online-avatar-placeholder,
[data-theme] .bday-avatar,
[data-theme] .today-avatar {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 65%, #000)) !important;
    color: #fff !important;
}
[data-theme] .online-avatar {
    border-color: var(--t-card-border) !important;
}

/* ── İzin talep form accent border ── */
[data-theme] .izn-talep-header {
    border-left-color: var(--t-accent) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .izn-liste-header {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Ayarlar (şifre değiştir) sayfası ── */
[data-theme] .settings-card {
    box-shadow: 0 4px 24px rgba(0,0,0,0.08) !important;
}
[data-theme] .settings-header h2 {
    color: var(--t-text) !important;
}
[data-theme] .accent {
    background: var(--t-accent) !important;
}
[data-theme] .pw-rules li {
    color: var(--t-text-muted) !important;
}

/* ── Masraf form alanı ── */
[data-theme] .form-grid .group label,
[data-theme] .group label {
    color: var(--t-text-muted) !important;
}
[data-theme] .form-header h2 {
    color: var(--t-text) !important;
}
[data-theme] .field-hint {
    color: var(--t-text-muted) !important;
}

/* ── Upload butonu ── */
[data-theme] .upload-btn {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
    color: var(--t-accent) !important;
}
[data-theme] .upload-btn:hover {
    background: color-mix(in srgb, var(--t-accent-light) 70%, var(--t-accent) 30%) !important;
}

/* ── Resim preview border ── */
[data-theme] .img-preview img {
    border-color: var(--t-card-border) !important;
}

/* ── Filter bar arka planı ── */
[data-theme] .filter-bar {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Avans kartları ve form ── */
[data-theme] .avans-card {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .avans-body,
[data-theme] .avans-list {
    color: var(--t-text) !important;
}
[data-theme] .avans-form {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .avans-form h4 {
    color: var(--t-text) !important;
}
[data-theme] .avans-toggle {
    color: var(--t-text-muted) !important;
}
[data-theme] .avans-card-meta {
    color: var(--t-text-muted) !important;
}
[data-theme] .avans-card-proje {
    color: var(--t-accent) !important;
}
[data-theme] .avans-select {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}

/* ── Ödeme detay satır (tablo içi açılan panel) ── */
[data-theme] .detay-row td {
    background: var(--t-hover) !important;
}
[data-theme] .odeme-detay-panel {
    border-left-color: var(--t-accent) !important;
}
[data-theme] .odeme-detay-panel.empty {
    color: var(--t-text-muted) !important;
}
[data-theme] .detay-header {
    color: var(--t-text) !important;
}
[data-theme] .detay-count {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .detay-table th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .detay-table td {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .detay-table tr:hover {
    background: var(--t-hover) !important;
}

/* ── Masraf tablo hover ve pill'ler ── */
[data-theme] .modern-table tr:hover {
    background: var(--t-hover) !important;
}
[data-theme] .patient-tag {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}

/* ── Yeşil list-header (Ödenenler bölümü) ── */
[data-theme] .list-header.green {
    background: var(--t-topbar) !important;
}
[data-theme] .td-tutar {
    color: #dc2626 !important;
}

/* ── Dashboard kartlarına hover efekti (tema uyumlu) ── */
[data-theme] .menu-card:hover {
    border-color: var(--t-accent) !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.12) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .icon-box {
    background: color-mix(in srgb, var(--t-accent) 10%, transparent) !important;
}
[data-theme] .menu-card:hover .icon-box {
    background: color-mix(in srgb, var(--t-accent) 18%, transparent) !important;
}

/* Çevrimiçi durum — baz kural Dashboard.razor.css'te; yarı-şeffaf yeşil
   tüm tema topbar arka planlarına (koyu/renkli) doğal olarak uyum sağlar. */

/* ── Eğitim video tamamlandı check ve sertifika ── */
[data-theme] .cert-body {
    color: var(--t-text) !important;
}
[data-theme] .cert-detail-item {
    color: var(--t-text) !important;
}
[data-theme] .video-player {
    color: var(--t-text) !important;
}

/* ── Eğitim sertifika banner (başarıyla tamamladınız) ── */
[data-theme] .sertifika-banner {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .sertifika-banner h2 {
    color: var(--t-text) !important;
}
[data-theme] .sertifika-banner p {
    color: var(--t-text-muted) !important;
}
[data-theme] .btn-sertifika {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 70%, #000 30%)) !important;
    color: #fff !important;
}

/* ── Eğitim kilitli ekran ── */
[data-theme] .locked-card {
    background: var(--t-card) !important;
    border-color: #fca5a5 !important;
}
[data-theme] .locked-card h2 {
    color: #dc2626 !important;
}
[data-theme] .locked-card p {
    color: var(--t-text-muted) !important;
}

/* ── Eğitim all-done-box (videolar tamamlandı) ── */
[data-theme] .all-done-box {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .all-done-box strong {
    color: var(--t-text) !important;
}
[data-theme] .all-done-box p {
    color: var(--t-text-muted) !important;
}

/* ── Already watched mesajı ── */
[data-theme] .already-watched {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}

/* ── Eğitim section card ve header ── */
[data-theme] .section-card {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .section-header {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Watch progress fill ── */
[data-theme] .watch-progress {
    background: var(--t-hover) !important;
}
[data-theme] .watch-progress-fill {
    background: linear-gradient(90deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 70%, #000 30%)) !important;
}
[data-theme] .watch-progress-fill.ready {
    background: linear-gradient(90deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 70%, #000 30%)) !important;
}
[data-theme] .watch-progress-text {
    color: var(--t-text-muted) !important;
}

/* ── Sonuç paneli ── */
[data-theme] .sonuc-panel {
    border-color: var(--t-card-border) !important;
}
[data-theme] .sonuc-panel.sonuc-ok {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .sonuc-ok h3 {
    color: var(--t-text) !important;
}
[data-theme] .sonuc-ok .puan-num {
    color: var(--t-accent) !important;
}
[data-theme] .sonuc-panel.sonuc-fail {
    background: var(--t-card) !important;
    border-color: #fca5a5 !important;
}
[data-theme] .sonuc-fail h3 {
    color: #dc2626 !important;
}
[data-theme] .sonuc-info {
    color: var(--t-text-muted) !important;
}

/* ── Sonuç pill'leri ── */
[data-theme] .sonuc-pill.basarili {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .sonuc-pill.basarisiz {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
[data-theme] .puan-ok {
    color: var(--t-accent) !important;
}

/* ═══════════════════════════════════════════════════════
   KULLANICI SAYFALARI — YEŞİL RENKLERİ TEMA UYUMLU YAP
   Semantik yeşil renkler (başarılı, onaylı, teslim) tema
   accent rengine bağlanır.
   ═══════════════════════════════════════════════════════ */

/* ── Ortak: success mesajları ── */
[data-theme] .form-message.success,
[data-theme] .ek-msg.success,
[data-theme] .dt-msg.success,
[data-theme] .ekm-toast.success {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}

/* ── Ekipmanlarım: pill, teslim ── */
[data-theme] .ekm-pill.green {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .td-teslim {
    color: var(--t-accent) !important;
}
[data-theme] .ekm-table tbody tr.row-delivered {
    border-left-color: var(--t-accent) !important;
}

/* ── Hakkımda: cert mini card, durum pill'leri ── */
[data-theme] .cert-mini-card.ok {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .badge-green {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}
/* Hakkımda profil şeridi — koyu gradient üzerindeki cam rozetler */
[data-theme] .profile-banner .badge-green {
    background: rgba(34, 197, 94, 0.25) !important;
    color: #bbf7d0 !important;
    border-color: rgba(34, 197, 94, 0.4) !important;
}
[data-theme] .profile-banner .badge-red {
    background: rgba(239, 68, 68, 0.25) !important;
    color: #fecaca !important;
    border-color: rgba(239, 68, 68, 0.4) !important;
}
[data-theme] .profile-banner .badge-blue {
    background: rgba(59, 130, 246, 0.25) !important;
    color: #bfdbfe !important;
    border-color: rgba(59, 130, 246, 0.4) !important;
}
[data-theme] .profile-banner .badge-purple {
    background: rgba(168, 85, 247, 0.25) !important;
    color: #e9d5ff !important;
    border-color: rgba(168, 85, 247, 0.4) !important;
}
[data-theme] .profile-banner .badge-orange {
    background: rgba(245, 158, 11, 0.3) !important;
    color: #fed7aa !important;
    border-color: rgba(245, 158, 11, 0.5) !important;
}
[data-theme] .profile-banner .badge-pink {
    background: rgba(236, 72, 153, 0.28) !important;
    color: #fbcfe8 !important;
    border-color: rgba(236, 72, 153, 0.5) !important;
}
[data-theme] .izin-durum.onaylandi {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}

/* ── İş Girişi: isg success mesajları, onaylı status ── */
[data-theme] .isg-msg.success,
[data-theme] .isg-status.onaylandi,
[data-theme] .isg-pill.basarili {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}

/* ── İzinlerim: bakiye, durum, hak günü ── */
[data-theme] .izn-bakiye-card.kalan {
    border-left-color: var(--t-accent) !important;
}
[data-theme] .izn-durum-pill.onaylandi {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .izn-hk-gun {
    color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}

/* ── Destek Taleplerim: filtre, kart, tur tag, durum pill ── */
[data-theme] .dt-filter.yanitlandi.active {
    background: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .dt-card.has-reply {
    background: var(--t-accent-light) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .dt-tur-tag.destek {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .dt-durum-pill.yanitlandi {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .dt-bubble.received .dt-bubble-name {
    color: var(--t-accent) !important;
}
[data-theme] .dt-btn-close {
    color: var(--t-accent) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .dt-btn-close:hover {
    background: var(--t-accent-light) !important;
}

/* ── Hastalar: durum pill, success mesaj ── */
[data-theme] .hasta-pill.aktif,
[data-theme] .status-aktif {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}

/* ── Masraf Girişi: pill'ler (değer renkleri scoped CSS'ten gelir) ── */
[data-theme] .list-header.green {
    background: var(--t-accent) !important;
}
[data-theme] .green-badge {
    background: var(--t-accent) !important;
}
[data-theme] .filter-btn.paid.active {
    background: var(--t-accent) !important;
}
[data-theme] .status-pill.paid {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .avans-durum-pill.green {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}

/* ── Masraf Girişi: üst kart hover ── */
[data-theme] .bal-item.clickable:hover {
    background: var(--t-accent-light) !important;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--t-accent) 20%, transparent) !important;
}
[data-theme] .bal-label {
    color: var(--t-text-muted) !important;
}
[data-theme] .bal-note {
    color: var(--t-text-muted) !important;
}
[data-theme] .bal-item.highlight {
    background: var(--t-hover) !important;
}
[data-theme] .bal-divider {
    background: var(--t-card-border) !important;
}
/* Bakiye kutusundaki nötr değer (positive/negative değilse) tema metin rengini alır */
[data-theme] .bal-bakiye .bal-val:not(.positive):not(.negative) {
    color: var(--t-text) !important;
}

/* ── Masraf Girişi: ödenen detay popup ── */
[data-theme] .odenen-panel {
    background: var(--t-card) !important;
}
[data-theme] .odenen-header {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-header h3 {
    color: var(--t-text) !important;
}
[data-theme] .odenen-close {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .odenen-section-title {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table td {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table tr:hover td {
    background: var(--t-hover) !important;
}
[data-theme] .odenen-table .tutar-cell {
    color: var(--t-accent) !important;
}
[data-theme] .odenen-subtotal {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .odenen-subtotal span {
    color: var(--t-text) !important;
}
[data-theme] .odenen-subtotal strong {
    color: var(--t-accent) !important;
}
[data-theme] .odenen-footer {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .odenen-grand-total {
    background: var(--t-accent-light) !important;
    border-color: var(--t-accent) !important;
}
[data-theme] .odenen-grand-total span {
    color: var(--t-text) !important;
}
[data-theme] .odenen-grand-total strong {
    color: var(--t-accent) !important;
}
[data-theme] .odenen-empty {
    color: var(--t-text-muted) !important;
}

/* ═══════════════════════════════════════════════════════
[data-theme] .list-header .search-bar,
[data-theme] .list-header .search-bar * {
    background: transparent !important;
    border-color: transparent !important;
}
[data-theme] .list-header .search-bar input,
[data-theme] .list-header input[type="text"],
[data-theme] .list-header input:not([type="hidden"]) {
    background: rgba(255,255,255,0.18) !important;
    border: 1px solid rgba(255,255,255,0.25) !important;
    border-radius: 20px !important;
    color: #fff !important;
}
[data-theme] .list-header .search-bar input::placeholder,
[data-theme] .list-header input::placeholder {
    color: rgba(255,255,255,0.5) !important;
}
[data-theme] .list-header .search-bar input:focus,
[data-theme] .list-header input:focus {
    background: rgba(255,255,255,0.25) !important;
    border-color: rgba(255,255,255,0.5) !important;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.1) !important;
}
[data-theme] .list-header .search-icon {
    color: rgba(255,255,255,0.6) !important;
}

/* ═══════════════════════════════════════════
   KOLON FİLTRE POPUP — Global Stiller
   Tüm yönetim sayfalarındaki cfp-* elemanlar
   ═══════════════════════════════════════════ */
.cfp-backdrop {
    position: fixed; top: 0; left: 0; width: 100%; height: 100%;
    z-index: 9000; background: rgba(0,0,0,0.15);
    display: flex; align-items: center; justify-content: center;
}
.cfp-dropdown {
    position: relative; z-index: 9001;
    background: white; border-radius: 14px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04);
    width: 320px; max-width: calc(100vw - 32px); max-height: 70vh;
    overflow: hidden; display: flex; flex-direction: column;
    animation: cfp-in 0.15s ease-out;
    text-transform: none; letter-spacing: 0; font-weight: 400;
}
@keyframes cfp-in {
    from { opacity: 0; transform: translateY(-8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cfp-header {
    padding: 12px 16px 10px; display: flex; align-items: center;
    justify-content: space-between; border-bottom: 1px solid #f1f5f9;
}
.cfp-title { font-weight: 800; font-size: 0.88rem; color: #1e293b; }
.cfp-close {
    border: none; background: #f1f5f9; color: #64748b;
    width: 28px; height: 28px; border-radius: 6px; cursor: pointer;
    font-size: 0.85rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.15s;
}
.cfp-close:hover { background: #fef2f2; color: #dc2626; }
.cfp-sort { padding: 10px 16px; }
.cfp-sort-btn {
    width: 100%; padding: 8px 14px; border: 1.5px solid #e2e8f0;
    border-radius: 8px; background: #f8fafc; font-size: 0.82rem;
    font-weight: 700; color: #475569; cursor: pointer;
    transition: all 0.15s; text-align: left;
}
.cfp-sort-btn:hover { border-color: #a5b4fc; background: #eef2ff; color: #4f46e5; }
.cfp-sort-btn.asc:hover { border-color: #86efac; background: #f0fdf4; color: #16a34a; }
.cfp-sort-btn.desc:hover { border-color: #fca5a5; background: #fef2f2; color: #dc2626; }
.cfp-divider { height: 1px; background: #e2e8f0; margin: 0; }
.cfp-search-wrap { padding: 10px 16px 6px; }
.cfp-search {
    width: 100%; padding: 7px 12px; border: 1.5px solid #e2e8f0;
    border-radius: 8px; font-size: 0.82rem; outline: none;
    box-sizing: border-box; transition: border 0.15s;
}
.cfp-search:focus { border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99,102,241,0.08); }
.cfp-actions { display: flex; gap: 4px; padding: 4px 16px 6px; }
.cfp-actions button {
    flex: 1; padding: 5px 8px; border: 1.5px solid #e2e8f0;
    border-radius: 6px; background: white; font-size: 0.75rem;
    font-weight: 700; color: #475569; cursor: pointer; transition: all 0.15s;
}
.cfp-actions button:hover { background: #eef2ff; border-color: #a5b4fc; color: #4f46e5; }
.cfp-list { flex: 1; overflow-y: auto; padding: 2px 0 6px; max-height: 200px; }
.cfp-item {
    display: flex; align-items: center; gap: 8px; padding: 5px 16px;
    cursor: pointer; font-size: 0.82rem; color: #334155; transition: background 0.1s;
}
.cfp-item:hover { background: #f8fafc; }
.cfp-item input[type="checkbox"] {
    width: 15px; height: 15px; accent-color: #6366f1; cursor: pointer; flex-shrink: 0;
}
.cfp-empty { padding: 12px; text-align: center; color: #94a3b8; font-size: 0.82rem; }

/* Kolon başlık ortak stiller */
.th-sf { cursor: pointer; user-select: none; position: relative; transition: all 0.15s; }
.th-sf:hover { color: #6366f1; background: #f0f4ff; }
.th-sf.filtered { color: #4f46e5; background: #eef2ff; }
.th-sf.filterable { border-bottom: 2.5px solid #c7d2fe; }
.th-sf.filterable.filtered { border-bottom-color: #6366f1; }
.col-filter-banner {
    display: flex; align-items: center; gap: 12px; padding: 8px 16px;
    margin-bottom: 8px; background: #eef2ff; border: 1.5px solid #c7d2fe;
    border-radius: 8px; font-size: 0.82rem; font-weight: 600; color: #4f46e5;
}
.col-filter-banner button {
    margin-left: auto; border: 1px solid #a5b4fc; background: white;
    color: #4f46e5; padding: 3px 10px; border-radius: 6px;
    font-size: 0.75rem; font-weight: 600; cursor: pointer;
}
.col-filter-banner button:hover { background: #eef2ff; }

@media (max-width: 768px) {
    .cfp-dropdown { width: 90vw; }
}

/* ═══════════════════════════════════════════
   AYARLAR PANELİ (sağdan kayan)
   ═══════════════════════════════════════════ */
.ayar-overlay {
    position: fixed; inset: 0; z-index: 10000;
    background: rgba(15,23,42,0.45); backdrop-filter: blur(4px);
    display: flex; justify-content: flex-end;
    animation: ayarFade 0.2s ease;
    transition: background 0.6s ease, backdrop-filter 0.6s ease;
}
.ayar-overlay.ayar-peek {
    background: rgba(15,23,42,0.03);
    backdrop-filter: blur(0px);
}
@keyframes ayarFade { from { opacity: 0; } to { opacity: 1; } }

.ayar-panel {
    width: 410px; max-width: 100vw; height: var(--app-height, 100dvh);
    background: var(--t-card, #fff);
    box-shadow: -8px 0 40px rgba(0,0,0,0.18);
    display: flex; flex-direction: column;
    animation: ayarSlide 0.3s cubic-bezier(0.16,1,0.3,1);
    color: var(--t-text, #1e293b);
}
@keyframes ayarSlide { from { transform: translateX(100%); } to { transform: translateX(0); } }

.ayar-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 24px; flex-shrink: 0;
    background: var(--t-sidebar, #1e293b); color: #fff;
}
.ayar-head h3 { margin: 0; font-size: 1.1rem; font-weight: 800; display: flex; align-items: center; gap: 10px; color: #fff !important; }
.ayar-x {
    background: rgba(255,255,255,0.15); border: none; color: #fff;
    width: 34px; height: 34px; border-radius: 10px; cursor: pointer;
    font-size: 1rem; display: flex; align-items: center; justify-content: center;
    transition: background 0.15s;
}
.ayar-x:hover { background: rgba(255,255,255,0.3); }

.ayar-body {
    flex: 1; overflow-y: auto; padding: 20px 24px 40px;
    display: flex; flex-direction: column; gap: 26px;
    -webkit-overflow-scrolling: touch;
}

.ayar-sec-title {
    font-size: 0.76rem; font-weight: 800; text-transform: uppercase;
    letter-spacing: 2px; color: var(--t-text-muted, #64748b);
    margin: 0 0 12px; padding-bottom: 8px;
    border-bottom: 2px solid var(--t-card-border, #e2e8f0);
    display: flex; align-items: center; gap: 8px;
}

/* Tema kartları grid */
.tema-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.tema-card {
    border: 2.5px solid var(--t-card-border, #e2e8f0);
    border-radius: 14px; padding: 12px 8px 10px; text-align: center;
    cursor: pointer; transition: all 0.2s; position: relative;
    background: var(--t-card, #fff);
}
.tema-card:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(0,0,0,0.1); }
.tema-card.secili { border-color: var(--t-accent, #6366f1); box-shadow: 0 0 0 3px rgba(99,102,241,0.2); }
.tema-card.secili::after {
    content: '✓'; position: absolute; top: 6px; right: 8px;
    font-size: 0.7rem; font-weight: 900;
    background: var(--t-accent, #6366f1); color: #fff;
    width: 18px; height: 18px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
}
.tema-onizleme { width: 100%; height: 38px; border-radius: 8px; margin-bottom: 8px; border: 1px solid rgba(0,0,0,0.06); }
.tema-adi { font-size: 0.73rem; font-weight: 700; color: var(--t-text, #1e293b); line-height: 1.2; }
.tema-emoji { font-size: 1rem; display: block; margin-bottom: 2px; }

/* Dil seçici butonları */
.tema-btn {
    padding: 10px 8px;
    border: 2px solid var(--t-card-border, #e2e8f0);
    border-radius: 10px;
    background: var(--t-card, #fff);
    cursor: pointer;
    text-align: center;
    transition: all 0.2s;
    color: var(--t-text, #1e293b);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2px;
}
.tema-btn:hover { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #f5f3ff); transform: translateY(-1px); }
.tema-btn.secili { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #eef2ff); font-weight: 800; box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-accent, #6366f1) 12%, transparent); }
.tema-btn .tb-baslik { font-size: 1.3rem; line-height: 1; display: flex; align-items: center; justify-content: center; }
.tema-btn .tb-baslik svg { width: 28px; height: 20px; border-radius: 3px; box-shadow: 0 0 1px rgba(0,0,0,0.2); }
.tema-btn .tb-alt { font-size: 0.68rem; font-weight: 600; color: var(--t-text-muted, #64748b); }

/* Font boyutu seçici */
.font-secenekler { display: flex; gap: 8px; }
.font-btn {
    flex: 1; padding: 10px 8px;
    border: 2px solid var(--t-card-border, #e2e8f0);
    border-radius: 10px; background: var(--t-card, #fff);
    cursor: pointer; text-align: center; transition: all 0.2s;
    color: var(--t-text, #1e293b);
}
.font-btn:hover { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #f5f3ff); }
.font-btn.secili { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #eef2ff); font-weight: 800; box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }
.font-btn .fb-baslik { display: block; font-weight: 700; margin-bottom: 2px; }
.font-btn .fb-alt   { color: var(--t-text-muted, #64748b); }

/* Yazı tipi seçici */
.ff-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: 8px;
}
.ff-btn {
    padding: 10px 6px;
    border: 2px solid var(--t-card-border, #e2e8f0);
    border-radius: 10px;
    background: var(--t-card, #fff);
    cursor: pointer;
    text-align: center;
    transition: all 0.2s;
    color: var(--t-text, #1e293b);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}
.ff-btn:hover { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #f5f3ff); }
.ff-btn.secili { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #eef2ff); box-shadow: 0 0 0 3px rgba(99,102,241,0.12); }
.ff-ornek { font-size: 1.3rem; font-weight: 700; line-height: 1; }
.ff-ad { font-size: 0.68rem; font-weight: 600; color: var(--t-text-muted, #64748b); }

/* Toggle switch */
.ayar-toggle-row {
    display: flex; align-items: center; justify-content: space-between;
    padding: 12px 0; border-bottom: 1px solid var(--t-card-border, #e2e8f0);
}
.ayar-toggle-row:last-child { border-bottom: none; }
.ayar-toggle-etiket { display: flex; flex-direction: column; gap: 2px; }
.ayar-toggle-etiket strong { font-size: 0.88rem; color: var(--t-text, #1e293b); }
.ayar-toggle-etiket span   { font-size: 0.78rem; color: var(--t-text-muted, #64748b); }
.ayar-switch {
    width: 48px; height: 26px; border-radius: 13px; border: none; cursor: pointer;
    position: relative; background: #cbd5e1; transition: background 0.2s; flex-shrink: 0; padding: 0;
}
.ayar-switch.acik { background: var(--t-accent, #6366f1); }
.ayar-switch::after {
    content: ''; position: absolute; top: 3px; left: 3px;
    width: 20px; height: 20px; border-radius: 50%;
    background: #fff; transition: transform 0.2s; box-shadow: 0 1px 4px rgba(0,0,0,0.15);
}
.ayar-switch.acik::after { transform: translateX(22px); }

/* Hızlı erişim linkleri */
.ayar-linkler { display: flex; flex-direction: column; gap: 6px; }
.ayar-link {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 16px; border-radius: 10px;
    border: 1.5px solid var(--t-card-border, #e2e8f0);
    background: var(--t-card, #fff); cursor: pointer; transition: all 0.15s;
    text-decoration: none; color: var(--t-text, #1e293b); font-weight: 600; font-size: 0.88rem;
}
.ayar-link:hover { border-color: var(--t-accent, #6366f1); background: var(--t-accent-light, #eef2ff); transform: translateX(4px); }
.ayar-link span:first-child { font-size: 1.1rem; width: 28px; text-align: center; }
.ayar-link-ok { margin-left: auto; color: var(--t-text-muted, #94a3b8); font-size: 0.8rem; }

/* Sıfırla butonu */
.ayar-reset-wrap {
    display: flex; flex-direction: column; gap: 8px;
    margin-top: 4px;
}
.ayar-sifirla {
    display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 12px; border: 2px dashed var(--t-card-border, #e2e8f0);
    border-radius: 10px; background: none; cursor: pointer;
    color: var(--t-text-muted, #64748b); font-weight: 700; font-size: 0.85rem;
    transition: all 0.2s; width: 100%;
}
.ayar-sifirla:hover { border-color: #ef4444; color: #ef4444; background: #fef2f2; }
.ayar-reset-hint {
    font-size: 0.72rem; color: var(--t-text-muted, #94a3b8);
    line-height: 1.5; text-align: center; padding: 0 4px;
}

/* Bilgi notu */
.ayar-bilgi-notu {
    display: flex; align-items: flex-start; gap: 8px;
    padding: 10px 14px; border-radius: 10px;
    background: var(--t-hover, #f0f9ff); border: 1px solid var(--t-card-border, #bae6fd);
    color: var(--t-text-muted, #0369a1); font-size: 0.74rem; line-height: 1.55;
}
.ayar-bilgi-notu > span:first-child { flex-shrink: 0; font-size: 0.85rem; margin-top: 1px; }

@media (max-width: 500px) {
    .ayar-panel { width: 100vw; height: var(--app-height, 100dvh); }
    .tema-grid  { grid-template-columns: repeat(2, 1fr); }
    .ayar-body  { padding: 16px 16px 48px; gap: 20px; }
}

/* ===== GLOBAL RESET & MOBILE ===== */
*, *::before, *::after {
    box-sizing: border-box;
}

html {
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    padding: 0;
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    -webkit-font-smoothing: antialiased;
}

img, svg {
    max-width: 100%;
    height: auto;
}

input, textarea, select, button {
    font-family: inherit;
    font-size: inherit;
}

/* Prevent horizontal scroll on any screen */
html, body {
    max-width: 100%;
    overscroll-behavior: none;
}

/* ═══ iOS PWA — alt safe-area beyaz boşluk fix ═══
   Standalone modda html/body arkaplanı tema rengiyle boyansın ki
   home indicator alanı ile aralarında beyaz şerit oluşmasın.
   --t-body :root'ta tanımlı, [data-theme="dark"] ile otomatik koyu olur. */
html, body {
    background-color: var(--t-body, #f1f5f9);
}
html.is-pwa, html.is-pwa body {
    background-color: var(--t-body, #f1f5f9);
    min-height: 100dvh;
}
/* iOS PWA: gövde tüm alanı kaplasın, alt safe-area da tema renginde olsun */
html.is-ios-pwa {
    /* iOS Safari standalone'da body sayfa yüksekliğinden kısa kalırsa
       arka plan html'den gelir. html'i tüm gerçek viewport'a (dvh) sabitliyoruz. */
    min-height: 100dvh;
    background-color: var(--t-body, #f1f5f9);
}
html.is-ios-pwa body {
    min-height: 100dvh;
    background-color: var(--t-body, #f1f5f9);
}

/* === iOS SELECT DROPDOWN FIX ===
   iOS Safari'de native <select> dropdown'lar� transform/scale uygulanm��
   parent elementlerde yanl�� konumda a��labiliyor. Bu fix ile:
   - Select elementi i�in positioning context olu�turulur
   - Transform'lar normalize edilir
   - Dropdown do�ru konumda a��l�r */
select {
    position: relative;
    -webkit-appearance: menulist-button;
}

@supports (-webkit-touch-callout: none) {
    /* iOS-specific select fixes */
    select {
        transform: translateZ(0);
        -webkit-transform: translateZ(0);
    }
    
    /* iOS PWA'da ek d�zeltmeler */
    html.is-ios-pwa select,
    html.is-pwa select {
        position: relative;
        transform: none;
        -webkit-transform: none;
    }
}

/* ═══ iOS PWA DOSYA SEÇİCİ FIX ═══
   display:none olan <input type="file"> iOS standalone PWA'da
   <label for> tıklamasını alamayabiliyor. Görünmez ama DOM'da
   etkileşilebilir tutuyoruz; böylece picker güvenle açılır. */
.pwa-file-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

/* Chat ek butonu — label disabled görünümü (button :disabled karşılığı) */
.chat-attach-btn-disabled {
    opacity: 0.4 !important;
    pointer-events: none !important;
    cursor: not-allowed !important;
}

/* Smooth scrolling — scroll container artık .main-content */
.main-content {
    scroll-behavior: smooth;
}

/* Touch-friendly tap targets */
@media (max-width: 767px) {
    /* Form elemanları — dokunma dostu minimum boyut */
    input, select, textarea {
        min-height: 36px;
    }

    /* Prevents iOS zoom on focus */
    input, textarea {
        font-size: 16px !important;
    }

    /* Sidebar / drawer arama kutuları — yönetimdeki ile aynı boyut */
    .sidebar-search input,
    .ku-drawer-search input {
        font-size: 0.85rem !important;
        min-height: auto !important;
        padding: 8px 12px !important;
    }

    /* Yönetim topbar geri butonu — mobilde gizle, floating pill kullanılacak */
    .ym-back { display: none !important; }

    /* iOS Safari — tarih input'ları sağdan taşma düzeltmesi */
    input[type="date"],
    input[type="datetime-local"],
    input[type="time"],
    input[type="month"],
    input[type="week"] {
        -webkit-appearance: none;
        appearance: none;
        max-width: 100%;
        min-width: 0;
        box-sizing: border-box;
    }
}

/* Masaüstünde yönetim sayfaları sidebar kadar içeri itilsin */
@media (min-width: 769px) {
    .ym-page { margin-left: 64px; transition: margin-left 0.25s cubic-bezier(0.16,1,0.3,1); }
    .ym-back { display: none !important; }
}

/* ═══ TOPBAR KULLANICI — durum rengi (ok + hafif arka plan parıltısı) ═══ */
.topbar-user-chevron-wrap {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-left: 2px;
    position: relative;
    flex-shrink: 0;
    color: var(--topbar-pres-accent, rgba(148, 163, 184, 0.92));
}
.topbar-user-chevron-wrap--neutral {
    color: rgba(148, 163, 184, 0.88);
}
.topbar-user-chevron {
    display: block;
    position: relative;
    z-index: 1;
}
.topbar-user-chevron-wrap:not(.topbar-user-chevron-wrap--neutral)::before {
    content: '';
    position: absolute;
    inset: -5px -3px;
    border-radius: 50%;
    background: radial-gradient(
        closest-side,
        color-mix(in srgb, var(--topbar-pres-accent) 38%, transparent),
        transparent 70%
    );
    opacity: 0.5;
    z-index: 0;
    animation: topbar-pres-glow 2.5s ease-in-out infinite;
    pointer-events: none;
}
@keyframes topbar-pres-glow {
    0%, 100% { opacity: 0.35; transform: scale(0.94); }
    50% { opacity: 0.72; transform: scale(1.06); }
}
.topbar-user-chevron-wrap:not(.topbar-user-chevron-wrap--neutral) .topbar-user-chevron {
    animation: topbar-chevron-nudge 2.2s ease-in-out infinite;
}
@keyframes topbar-chevron-nudge {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(2px); }
}
@media (prefers-reduced-motion: reduce) {
    .topbar-user-chevron-wrap::before,
    .topbar-user-chevron-wrap .topbar-user-chevron {
        animation: none !important;
    }
}

/* ═══ KULLANICI TOPBAR ═══ */
.ku-topbar {
    background: linear-gradient(135deg, #1e293b, #334155);
    padding: 0 30px;
    display: flex;
    align-items: center;
    gap: 16px;
    height: 56px;
    min-height: 56px;
    box-sizing: border-box;
    position: relative;
    z-index: 100;
}
.ku-back-btn {
    height: 34px; width: 34px; display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.08); border: 1.5px solid rgba(255,255,255,0.15);
    border-radius: 10px; cursor: pointer; font-weight: 700; font-size: 1rem;
    color: #e2e8f0; transition: all 0.2s; flex-shrink: 0; padding: 0;
}
.ku-back-btn:hover { background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.35); }
.ku-topbar h2 {
    margin: 0;
    color: #f8fafc;
    font-size: clamp(0.85rem, 2.5vw, 1.2rem);
    font-weight: 700;
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
    display: flex;
    align-items: center;
    gap: 10px;
}
.ku-topbar .ku-topbar-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    filter: drop-shadow(0 2px 3px rgba(0,0,0,0.25));
}
.ku-topbar .ku-topbar-icon svg.ms-icon { width: 32px; height: 32px; display: block; }
.ku-topbar .ku-topbar-title {
    overflow: hidden;
    text-overflow: ellipsis;
    min-width: 0;
}
@media (max-width: 600px) {
    .ku-topbar .ku-topbar-icon { width: 26px; height: 26px; }
    .ku-topbar .ku-topbar-icon svg.ms-icon { width: 26px; height: 26px; }
}

/* Kullanıcı topbar — oturum butonu (yönetimdekiyle aynı) */
.ku-topbar .ym-topbar-user { margin-left: auto; display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.ku-topbar .ym-user-menu-wrap { position: relative; }
.ku-topbar .ym-topbar-ubtn {
    padding: 6px 16px; border-radius: 10px; border: 1.5px solid rgba(255,255,255,0.18);
    background: rgba(255,255,255,0.08); color: #e2e8f0; font-weight: 600;
    font-size: 0.88rem; cursor: pointer; transition: background 0.2s, border-color 0.2s;
    display: flex; align-items: center; gap: 10px; min-height: 40px; box-sizing: border-box;
    white-space: nowrap;
    position: relative;
    z-index: 0;
}
.ku-topbar .ku-user-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    min-width: 0;
    gap: 0;
    line-height: 1.15;
}
.ku-topbar .ym-topbar-ubtn .ku-username-text {
    font-weight: 600;
    font-size: 0.88rem;
    max-width: 14rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ku-topbar .ku-presence-inline {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-top: 2px;
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    color: rgba(226, 232, 240, 0.82);
    max-width: 14rem;
}
.ku-topbar .ku-presence-inline-label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ku-topbar .ku-presence-inline-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.ku-topbar .ku-presence-inline-musait .ku-presence-inline-dot { background: #4ade80; }
.ku-topbar .ku-presence-inline-mesgul .ku-presence-inline-dot { background: #fbbf24; }
.ku-topbar .ku-presence-inline-rahatsiz_etme .ku-presence-inline-dot { background: #f87171; }
.ku-topbar .ku-presence-inline-gorunmez .ku-presence-inline-dot { background: #94a3b8; }
@media (max-width: 520px) {
    .ku-topbar .ku-presence-inline { margin-top: 0; font-size: 0.62rem; max-width: 9rem; }
    .ku-topbar .ku-presence-inline-label { display: inline-block; max-width: 8rem; }
}
@media (prefers-reduced-motion: reduce) {
    .ku-topbar .ym-topbar-ubtn { transition: none; }
}
.ku-topbar .ym-topbar-ubtn:hover {
    background: rgba(255,255,255,0.14);
    border-color: rgba(255,255,255,0.32);
}
.ku-topbar .ym-topbar-ubtn .hb-icon { font-size: 0.92rem; flex-shrink: 0; }
.ku-topbar .ym-arrow.topbar-user-chevron-wrap {
    margin-left: 0;
    font-size: 0.58rem;
    color: rgba(226, 232, 240, 0.55);
    line-height: 1;
    width: 1em;
    text-align: center;
    font-family: system-ui, sans-serif;
}
.ku-topbar .ym-arrow.topbar-user-chevron-wrap .topbar-user-chevron { display: none; }
.ku-topbar .ym-topbar-dropdown {
    position: absolute; top: calc(100% + 6px); right: 0; min-width: 220px;
    background: white; border-radius: 12px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.3); border: 1px solid #e2e8f0; z-index: 2000; overflow: hidden;
}
.ku-topbar .ym-td-item {
    display: flex; align-items: center; gap: 10px; width: 100%;
    padding: 12px 18px; border: none; background: none; cursor: pointer;
    font-size: 0.88rem; font-weight: 600; color: #334155; transition: all 0.15s; text-align: left;
}
.ku-topbar .ym-td-item:hover { background: #f0f9ff; color: #0369a1; }
.ku-topbar .ym-td-item.ym-td-exit { color: #dc2626; border-top: 1px solid #f1f5f9; }
.ku-topbar .ym-td-item.ym-td-exit:hover { background: #fef2f2; color: #b91c1c; }

@media (max-width: 768px) {
    .ku-topbar { padding: 0 12px; gap: 10px; }
}
@media (max-width: 600px) {
    .ku-topbar .ym-topbar-ubtn { padding: 5px 10px; font-size: 0.8rem; gap: 6px; min-height: 34px; height: auto; }
    .ku-topbar .ym-topbar-user { gap: 4px; }
    .ku-topbar .ym-topbar-ubtn .ku-username-text { font-size: 0.8rem; max-width: 9rem; }
}

/* ═══ KULLANICI NAVİGASYON DRAWER ═══ */
.ku-drawer-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.4);
    z-index: 5000; animation: ku-fade-in 0.2s ease;
}
.ku-drawer-overlay.closing {
    animation: ku-fade-out 0.22s ease forwards;
}
@keyframes ku-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes ku-fade-out { from { opacity: 1; } to { opacity: 0; } }

.ku-drawer {
    position: fixed; top: 0; left: 0; bottom: 0; width: 280px;
    background: #fff; z-index: 5001; display: flex; flex-direction: column;
    box-shadow: 4px 0 24px rgba(0,0,0,0.15);
    animation: ku-slide-in 0.25s cubic-bezier(0.4,0,0.2,1);
    padding-top: env(safe-area-inset-top, 0px);
    padding-bottom: env(safe-area-inset-bottom, 0px);
}
.ku-drawer.closing {
    animation: ku-slide-out 0.22s ease forwards;
}
@keyframes ku-slide-in { from { transform: translateX(-100%); } to { transform: translateX(0); } }
@keyframes ku-slide-out { from { transform: translateX(0); } to { transform: translateX(-100%); } }

.ku-drawer-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 20px; background: linear-gradient(135deg, #1e293b, #334155);
    color: white; flex-shrink: 0;
}
.ku-drawer-title { font-size: 1.1rem; font-weight: 800; letter-spacing: 1px; }
.ku-drawer-close {
    background: rgba(255,255,255,0.15); border: none; color: white;
    width: 30px; height: 30px; border-radius: 8px; cursor: pointer;
    font-size: 0.9rem; display: flex; align-items: center; justify-content: center;
    transition: background 0.15s;
}
.ku-drawer-close:hover { background: rgba(255,255,255,0.25); }

.ku-drawer-search {
    padding: 10px 16px; flex-shrink: 0; background: #f8fafc;
    border-bottom: 1px solid #e2e8f0;
    position: relative;
}
.ku-drawer-search input {
    width: 100%; padding: 9px 12px 9px 38px; border: 1.5px solid #e2e8f0;
    border-radius: 10px; font-size: 0.85rem; background: #fff;
    outline: none; transition: border-color 0.15s;
}
.ku-drawer-search input:focus { border-color: #6366f1; }
.ku-drawer-search-icon {
    position: absolute;
    left: 26px;
    top: 50%;
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    pointer-events: none;
    filter: drop-shadow(0 1px 1.5px rgba(0,0,0,0.12));
}
.ku-drawer-search-icon svg { width: 18px; height: 18px; }

.ku-drawer-nav {
    flex: 1; overflow-y: auto; padding: 8px 0;
    scrollbar-width: thin; scrollbar-color: transparent transparent;
}
.ku-drawer-nav::-webkit-scrollbar { width: 3px; }
.ku-drawer-nav::-webkit-scrollbar-track { background: transparent; }
.ku-drawer-nav::-webkit-scrollbar-thumb { background: transparent; border-radius: 20px; }
.ku-drawer-nav.scroll-active { scrollbar-color: rgba(0,0,0,0.10) transparent; }
.ku-drawer-nav.scroll-active::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.10); }
.ku-drawer-link {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 20px; color: #334155; font-size: 0.88rem; font-weight: 600;
    text-decoration: none; transition: all 0.15s; border-left: 3px solid transparent;
}
.ku-drawer-link:hover { background: #f8fafc; color: #4f46e5; }
.ku-drawer-link.active {
    background: #eef2ff; color: #4f46e5; border-left-color: #6366f1; font-weight: 700;
}
/* Drawer açılınca aktif öğeye dikkat çeken pulse */
.ku-drawer-link.drawer-highlight {
    animation: drawer-pulse 1.4s ease-out;
}
@keyframes drawer-pulse {
    0%   { box-shadow: inset 0 0 0 0 rgba(99,102,241,0.45), 0 0 12px rgba(99,102,241,0.3); }
    30%  { box-shadow: inset 0 0 0 2px rgba(99,102,241,0.35), 0 0 18px rgba(99,102,241,0.2); }
    100% { box-shadow: none; }
}
.ku-drawer-link span { font-size: 1.1rem; width: 24px; text-align: center; flex-shrink: 0; }
.ku-drawer-link .ku-drawer-link-icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 26px; height: 26px; min-width: 26px;
    filter: drop-shadow(0 1px 2px rgba(15,23,42,0.2));
    transition: transform 0.18s ease;
}
.ku-drawer-link .ku-drawer-link-icon svg.ms-icon { width: 22px; height: 22px; display: block; }
.ku-drawer-link:hover .ku-drawer-link-icon { transform: scale(1.08); }
.ku-drawer-link.active .ku-drawer-link-icon { filter: drop-shadow(0 2px 3px rgba(99,102,241,0.35)); }

.ku-drawer-footer {
    border-top: 1px solid #e2e8f0; padding: 8px 0; flex-shrink: 0;
}
.ku-drawer-footer .ku-drawer-link { color: #6366f1; font-weight: 500; }
.ku-drawer-footer .ku-drawer-link.ku-drawer-home { color: #334155 !important; font-weight: 600 !important; }
.ku-drawer-admin { color: #4f46e5 !important; }
.ku-drawer-exit { color: #dc2626 !important; }
.ku-drawer-exit:hover { background: #fef2f2 !important; }

/* ═══ DRAWER DOĞUM GÜNÜ EFEKTİ ═══ */
.drawer-bday {
    background: linear-gradient(90deg, rgba(244,114,182,0.1) 0%, rgba(168,85,247,0.06) 100%) !important;
    border-left: 3px solid #f472b6 !important;
}
.drawer-bday:hover {
    background: linear-gradient(90deg, rgba(244,114,182,0.18) 0%, rgba(168,85,247,0.12) 100%) !important;
}
.drawer-bday-badge {
    margin-left: auto;
    background: linear-gradient(135deg, #ec4899, #a855f7);
    color: #fff;
    font-size: 0.68rem;
    font-weight: 800;
    padding: 2px 8px;
    border-radius: 10px;
    white-space: nowrap;
    animation: drawerBdayPulse 2s ease-in-out infinite;
}
@keyframes drawerBdayPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}

/* ═══ DRAWER PEEK İPUCU ANİMASYONU ═══ */
.ku-peek-hint {
    position: fixed; top: 0; left: 0; bottom: 0; width: 52px;
    z-index: 4999; cursor: pointer;
    animation: ku-peek-anim 3s ease-in-out forwards;
}
@keyframes ku-peek-anim {
    0%   { transform: translateX(-100%); opacity: 0; }
    12%  { transform: translateX(0); opacity: 1; }
    70%  { transform: translateX(0); opacity: 1; }
    85%  { transform: translateX(8px); opacity: 1; }
    100% { transform: translateX(-100%); opacity: 0; }
}
.ku-peek-bar {
    position: absolute; top: 50%; right: 0;
    transform: translateY(-50%);
    background: linear-gradient(135deg, #4f46e5, #6366f1);
    color: white; border-radius: 0 14px 14px 0;
    padding: 14px 10px 14px 8px;
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    box-shadow: 4px 0 20px rgba(99,102,241,0.35);
}
.ku-peek-arrow {
    font-size: 1.2rem; font-weight: 900; line-height: 1;
    animation: ku-peek-pulse 0.8s ease-in-out infinite alternate;
}
@keyframes ku-peek-pulse {
    from { transform: translateX(0); }
    to   { transform: translateX(4px); }
}
.ku-peek-text {
    font-size: 0.62rem; font-weight: 800; text-transform: uppercase;
    letter-spacing: 1px; writing-mode: vertical-rl; text-orientation: mixed;
}

/* Yönetim topbar yüksekliği — sidebar header ile eşleşsin (56px) */
.ym-topbar {
    height: 56px !important;
    min-height: 56px !important;
    max-height: 56px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    box-sizing: border-box !important;
    flex-wrap: nowrap !important;
    overflow: visible;
    position: relative;
    z-index: 100;
}
.ym-topbar h2 {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    min-width: 0 !important;
    font-size: clamp(0.85rem, 2.5vw, 1.2rem) !important;
}

/* ═══ YÖNETİM TABLO ALANLARI — max-height ile sınırla, sticky header ═══ */
.ym-table-wrap,
.hy-table-wrap,
.ey-table-wrap,
.ek-table-wrap,
.igt-table-wrap,
.my-table-wrap,
.sv-table-wrap,
.yk-table-wrap,
.arsiv-table-wrap,
.ym-izin-table-wrap {
    max-height: calc(var(--app-height, 100vh) - 220px);
    overflow-y: auto;
    overflow-x: auto;
}
/* Kolon filtreleme paneli açıkken overflow kısıtlama */
.ym-table-wrap.cfp-open,
.igt-table-wrap.cfp-open,
.ekm-table-wrap.cfp-open {
    overflow: visible !important;
    max-height: none !important;
}
/* Sticky thead — scroll ederken başlıklar sabit kalsın */
.ym-table-wrap thead th,
.hy-table-wrap thead th,
.ey-table-wrap thead th,
.ek-table-wrap thead th,
.igt-table-wrap thead th,
.my-table-wrap thead th,
.sv-table-wrap thead th,
.yk-table-wrap thead th,
.arsiv-table-wrap thead th,
.ym-izin-table-wrap thead th {
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--t-hover, #fafbfc);
}
/* Destek merkezi liste */
.dm-list {
    max-height: calc(var(--app-height, 100vh) - 260px);
}

/* ═══ KULLANICI TABLO ALANLARI — max-height ile sınırla, sticky header ═══ */
.table-responsive,
.ekm-table-wrap,
.izn-table-wrap {
    max-height: calc(var(--app-height, 100vh) - 240px);
    overflow-y: auto;
    overflow-x: auto;
}
/* Sticky thead — kullanıcı tabloları */
.table-responsive thead th,
.table-responsive .modern-table th,
.ekm-table-wrap thead th,
.izn-table-wrap thead th {
    position: sticky;
    top: 0;
    z-index: 5;
    background: var(--t-hover, #fafbfc);
}

/* ===== SEARCHABLE SELECT COMPONENT ===== */
.ss-wrap {
    position: relative;
    z-index: 10;
}
.ss-wrap:focus-within {
    z-index: 9999;
}

.ss-wrap .m-input {
    height: 40px;
    box-sizing: border-box;
    padding-right: 32px;
}

/* ===== GLOBAL INPUT STYLES ===== */
.m-input {
    padding: 9px 12px;
    border: 1.5px solid #cbd5e1;
    border-radius: 8px;
    font-size: 0.9rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    transition: 0.2s;
    background: #fcfdfe;
    box-sizing: border-box;
}

.m-input:focus {
    border-color: #0ea5e9;
    background: white;
    outline: none;
    box-shadow: 0 0 0 4px rgba(14, 165, 233, 0.1);
}

.m-input:disabled {
    background: #f1f5f9;
    color: #94a3b8;
    cursor: not-allowed;
    opacity: 0.8;
}

.m-input.input-warning {
    border-color: #f59e0b;
    background: #fffbeb;
}

.field-hint {
    display: block;
    font-size: 0.8rem;
    color: #d97706;
    margin-top: 4px;
    font-weight: 600;
}

select.m-input {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236366f1' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
    cursor: pointer;
}

/* ===== MODERN SELECT / DROPDOWN ===== */
select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%236366f1' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 10px 6px;
    padding-right: 38px !important;
    cursor: pointer;
    background-color: white;
    border: 1.5px solid #cbd5e1;
    border-radius: 8px;
    font-size: 0.88rem;
    font-weight: 600;
    color: #1e293b;
    transition: border-color 0.2s, box-shadow 0.2s, background-color 0.2s;
    outline: none;
    box-sizing: border-box;
    line-height: 1.4;
}
select:hover {
    border-color: #a5b4fc;
    background-color: #f8fafc;
}
select:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

/* Style native option elements */
select option {
    padding: 10px 14px;
    font-size: 0.88rem;
    background: white;
    color: #1e293b;
}
select option:checked {
    background: linear-gradient(135deg, #eef2ff, #e0e7ff);
    color: #4338ca;
    font-weight: 600;
}
select option:hover {
    background: #f1f5f9;
}

/* Mobil select — taşma ve dokunma dostu */
@media (max-width: 767px) {
    select {
        font-size: 16px !important;
        padding: 10px 38px 10px 12px !important;
        max-width: 100%;
        border-radius: 10px;
    }
}

/* SearchSelect açık durum */
.ss-wrap input.ss-open {
    border-color: #0ea5e9;
    border-radius: 8px 8px 0 0;
    box-shadow: 0 0 0 3px rgba(14, 165, 233, 0.1);
}

.ss-panel {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    max-height: 220px;
    overflow-y: auto;
    background: #fff;
    border: 1.5px solid #0ea5e9;
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    z-index: 99999;
    box-sizing: border-box;
}

.ss-item {
    padding: 10px 14px;
    cursor: pointer;
    font-size: 0.92rem;
    transition: background 0.1s;
    border-bottom: 1px solid #f1f5f9;
}

.ss-item:last-child {
    border-bottom: none;
}

.ss-item:hover {
    background: #eff6ff;
    color: #0369a1;
}

.ss-hl {
    background: #eff6ff;
    color: #0369a1;
}

.ss-sel {
    background: #e0f2fe;
    font-weight: 700;
    color: #0369a1;
}

.ss-match {
    background: #fef08a;
    color: inherit;
    border-radius: 2px;
    padding: 0 1px;
}

.ss-clear {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 20px;
    border: none;
    background: rgba(148,163,184,0.15);
    color: #64748b;
    border-radius: 50%;
    font-size: 0.65rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s, color 0.15s;
    z-index: 2;
    padding: 0;
    line-height: 1;
}

.ss-clear:hover {
    background: rgba(239,68,68,0.12);
    color: #ef4444;
}

.ss-empty {
    padding: 14px;
    color: #94a3b8;
    text-align: center;
    font-size: 0.88rem;
}

.ss-panel::-webkit-scrollbar { width: 5px; }
.ss-panel::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 3px; }

/* SearchSelect mobil */
@media (max-width: 600px) {
    .ss-panel {
        max-height: 180px;
    }
}

/* ═══ YÖNETİM TOPBAR KULLANICI BİLGİSİ ═══ */
.ym-topbar-user {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-left: auto;
}
.ym-topbar-user .ym-user-menu-wrap {
    position: relative;
}
.ym-topbar-ubtn {
    padding: 8px 18px;
    border-radius: 10px;
    border: 1.5px solid rgba(255,255,255,0.2);
    background: rgba(255,255,255,0.08);
    color: #e2e8f0;
    font-weight: 600;
    font-size: 0.85rem;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
    display: flex;
    align-items: center;
    gap: 8px;
    height: 40px;
    box-sizing: border-box;
}
.ym-topbar-ubtn:hover {
    background: rgba(255,255,255,0.15);
    border-color: rgba(255,255,255,0.35);
}
.ym-topbar-ubtn .ym-arrow.topbar-user-chevron-wrap {
    margin-left: 2px;
}
/* Modül içi ym-topbar-ubtn — presence inline (kullanıcı topbar ile aynı) */
.ym-topbar-ubtn { min-height: 40px; height: auto; }
.ym-topbar-ubtn .hb-icon { font-size: 0.95rem; line-height: 1; flex-shrink: 0; }
.ym-topbar-ubtn .ku-user-stack {
    display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
    min-width: 0; gap: 0; line-height: 1.15;
}
.ym-topbar-ubtn .ku-username-text {
    font-weight: 600; font-size: 0.85rem; max-width: 14rem;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ym-topbar-ubtn .ku-presence-inline {
    display: inline-flex; align-items: center; gap: 5px; margin-top: 2px;
    font-size: 0.66rem; font-weight: 600; letter-spacing: 0.02em;
    color: rgba(226, 232, 240, 0.82); max-width: 14rem;
}
.ym-topbar-ubtn .ku-presence-inline-label {
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ym-topbar-ubtn .ku-presence-inline-dot {
    width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.ym-topbar-ubtn .ku-presence-inline-musait .ku-presence-inline-dot { background: #4ade80; }
.ym-topbar-ubtn .ku-presence-inline-mesgul .ku-presence-inline-dot { background: #fbbf24; }
.ym-topbar-ubtn .ku-presence-inline-rahatsiz_etme .ku-presence-inline-dot { background: #f87171; }
.ym-topbar-ubtn .ku-presence-inline-gorunmez .ku-presence-inline-dot { background: #94a3b8; }
@media (max-width: 600px) {
    /* Mobilde kullanıcı adının altındaki durum satırını gizle — buton yüksekliği
       diğer topbar öğeleri (34px) ile eşit kalsın. */
    .ym-topbar-ubtn .ku-presence-inline { display: none !important; }
    .ym-topbar-ubtn .ku-username-text { max-width: 9rem; font-size: 0.8rem; line-height: 1; }
    .ym-topbar-ubtn .ku-user-stack { flex-direction: row; align-items: center; gap: 0; line-height: 1; }
}
.ym-topbar-dropdown {
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 220px;
    background: white;
    border-radius: 12px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.3);
    border: 1px solid #e2e8f0;
    z-index: 2000;
    overflow: hidden;
    animation: ymTdSlide 0.2s ease;
}
@keyframes ymTdSlide {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}
.ym-td-item {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    padding: 12px 18px;
    border: none;
    background: none;
    cursor: pointer;
    font-size: 0.88rem;
    font-weight: 600;
    color: #334155;
    transition: all 0.15s;
    text-align: left;
}
.ym-td-item:hover {
    background: #f0f9ff;
    color: #0369a1;
}
.ym-td-item.ym-td-exit {
    color: #dc2626;
    border-top: 1px solid #f1f5f9;
}
.ym-td-item.ym-td-exit:hover {
    background: #fef2f2;
    color: #b91c1c;
}
@media (max-width: 600px) {
    .ym-topbar-user { gap: 4px; }
    .ym-topbar-ubtn {
        height: 34px; min-height: 34px; max-height: 34px;
        font-size: 0.78rem; padding: 0 10px; border-radius: 8px; line-height: 1;
    }
    .ym-topbar-dropdown { right: 0; min-width: 200px; }
}

/* ═══ Görüntüleme Modu Banner ═══ */
.ym-viewonly-banner {
    display: flex;
    align-items: center;
    gap: 14px;
    background: linear-gradient(135deg, #fef3c7 0%, #fff7ed 100%);
    border: 1.5px solid #f59e0b;
    border-left: 5px solid #f59e0b;
    border-radius: 10px;
    padding: 14px 20px;
    margin: 8px 16px 14px 16px;
    box-shadow: 0 2px 8px rgba(245, 158, 11, 0.10);
    animation: ym-viewonly-slide 0.4s ease;
}
.ym-viewonly-icon {
    font-size: 1.7rem;
    flex-shrink: 0;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.08));
}
.ym-viewonly-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.ym-viewonly-content strong {
    color: #92400e;
    font-size: 0.95rem;
    letter-spacing: 0.02em;
}
.ym-viewonly-content span {
    color: #a16207;
    font-size: 0.85rem;
}
@keyframes ym-viewonly-slide {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ═══ Kendi Profili Uyarı ═══ */
.ym-kendi-uyari {
    font-size: 0.82rem;
    color: #b45309;
    background: #fef3c7;
    border: 1px solid #fbbf24;
    border-radius: 6px;
    padding: 5px 10px;
    margin-top: 4px;
}

/* ═══ RECONNECT — stiller ReconnectModal.razor.css'te ═══ */

/* ═══ SCROLL TO TOP BUTTON (draggable + edge-snap + progress ring) ═══ */
.scroll-top-btn {
    position: fixed;
    left: calc(100vw - 70px);
    top: calc(var(--app-height, 100vh) - 68px);
    width: 44px;
    height: 44px;
    border: none;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1, #818cf8);
    color: white;
    font-size: 1rem;
    font-weight: 800;
    cursor: pointer;
    z-index: 8000;
    box-shadow: 0 4px 16px rgba(99,102,241,0.35);
    opacity: 0;
    pointer-events: none;
    touch-action: none;
    user-select: none;
    transition: opacity 0.3s;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.scroll-top-btn .stb-ring {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    transform: rotate(-90deg);
    pointer-events: none;
}
.scroll-top-btn .stb-ring-bg {
    fill: none;
    stroke: rgba(255,255,255,0.2);
    stroke-width: 3;
}
.scroll-top-btn .stb-ring-fill {
    fill: none;
    stroke: white;
    stroke-width: 3;
    stroke-linecap: round;
    transition: stroke-dashoffset 0.15s ease;
}
.scroll-top-btn .stb-arrow {
    position: relative;
    z-index: 1;
    font-size: 0.85rem;
    line-height: 1;
}
.scroll-top-btn.visible {
    opacity: 1;
    pointer-events: auto;
}
.scroll-top-btn:active {
    box-shadow: 0 2px 8px rgba(99,102,241,0.5);
}
.scroll-top-btn.snapping {
    transition: left 0.25s cubic-bezier(0.16,1,0.3,1),
                top 0.25s cubic-bezier(0.16,1,0.3,1),
                opacity 0.3s;
}
@media (max-width: 767px) {
    .scroll-top-btn { display: none !important; }
}

/* ═══ SAYFA GEÇİŞ ANİMASYONU ═══ */
.main-content {
    animation: page-fade-in 0.3s ease;
}
@keyframes page-fade-in {
    from { opacity: 0; transform: translateY(6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ═══ GLOBAL TOAST BİLDİRİM SİSTEMİ ═══ */
.toast-container {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 2147483000; /* modal/overlay'lerin üstünde kalması için maksimuma yakın */
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
    max-width: 420px;
    width: calc(100% - 40px);
}
.toast-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-radius: 12px;
    font-size: 0.88rem;
    font-weight: 600;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18);
    pointer-events: auto;
    animation: toastIn 0.35s cubic-bezier(0.16,1,0.3,1);
    backdrop-filter: blur(10px);
    cursor: pointer;
    transition: transform 0.3s cubic-bezier(0.16,1,0.3,1),
                opacity 0.3s ease,
                margin 0.3s cubic-bezier(0.16,1,0.3,1);
}
.toast-item.toast-success {
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
    border: 1.5px solid #86efac;
    color: #15803d;
}
.toast-item.toast-error {
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
    border: 1.5px solid #fca5a5;
    color: #b91c1c;
}
.toast-icon {
    font-size: 1.2rem;
    flex-shrink: 0;
}
.toast-text {
    flex: 1;
    line-height: 1.4;
}
.toast-close {
    background: none;
    border: none;
    color: inherit;
    opacity: 0.5;
    cursor: pointer;
    font-size: 0.85rem;
    padding: 2px 6px;
    border-radius: 4px;
    flex-shrink: 0;
    transition: opacity 0.15s;
}
.toast-close:hover {
    opacity: 1;
}
.toast-item.toast-out {
    animation: toastOut 0.3s ease forwards;
}
@keyframes toastIn {
    from { opacity: 0; transform: translateX(120px) scale(0.95); }
    to { opacity: 1; transform: translateX(0) scale(1); }
}
@keyframes toastOut {
    from { opacity: 1; transform: translateX(0) scale(1); max-height: 100px; margin-bottom: 0; }
    to { opacity: 0; transform: translateX(120px) scale(0.95); max-height: 0; margin-bottom: -10px; }
}
@media (max-width: 600px) {
    .toast-container {
        top: 12px; right: 12px; left: 12px;
        width: auto; max-width: none;
    }
    .toast-item { font-size: 0.82rem; padding: 12px 14px; }
}

/* ═══ TÜM MESAJ/UYARI KUTULARI → FIXED TOAST ═══ */
.ym-message,
.dm-message,
.igt-message,
.ek-msg,
.ey-msg,
.my-message,
.my-msg,
.hy-message,
.sv-message,
.yk-msg,
.sl-msg,
.dt-msg,
.s-msg,
.qm-msg,
.form-message {
    position: fixed !important;
    top: 20px !important;
    right: 20px !important;
    left: auto !important;
    width: auto !important;
    max-width: 420px !important;
    z-index: 99998 !important;
    margin: 0 !important;
    padding: 14px 42px 14px 18px !important;
    border-radius: 12px !important;
    font-size: 0.88rem !important;
    font-weight: 600 !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18) !important;
    backdrop-filter: blur(10px) !important;
    animation: toastIn 0.4s cubic-bezier(0.16,1,0.3,1) !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}
.ym-message.success,
.dm-message.success,
.igt-message.success,
.ek-msg.success,
.ey-msg.success,
.my-message.success,
.my-msg.success,
.hy-message.success,
.sv-message.success,
.yk-msg.success,
.sl-msg.success,
.dt-msg.success,
.s-msg.success,
.qm-msg.success,
.form-message.success {
    background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%) !important;
    border: 1.5px solid #86efac !important;
    color: #15803d !important;
}
.ym-message.error,
.dm-message.error,
.igt-message.error,
.ek-msg.error,
.ey-msg.error,
.my-message.error,
.my-msg.error,
.hy-message.error,
.sv-message.error,
.yk-msg.error,
.sl-msg.error,
.dt-msg.error,
.s-msg.error,
.qm-msg.error,
.form-message.error {
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%) !important;
    border: 1.5px solid #fca5a5 !important;
    color: #b91c1c !important;
}
@media (max-width: 600px) {
    .ym-message, .dm-message, .igt-message, .ek-msg, .ey-msg,
    .my-message, .my-msg, .hy-message, .sv-message, .yk-msg, .sl-msg,
    .dt-msg, .s-msg, .qm-msg, .form-message {
        right: 12px !important;
        left: 12px !important;
        max-width: none !important;
        font-size: 0.82rem !important;
        padding: 12px 14px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   LOGIN & SİSTEM SEÇİM POPUP — TEMA İZOLASYONU
   Bu alanlar her zaman orijinal (light) tasarımda kalır.
   ═══════════════════════════════════════════════════════════════ */

/* Login sayfası — font ölçeklemesinden izole et */
[data-theme] .login-page {
    background:
        radial-gradient(ellipse at 20% 80%, rgba(219, 234, 254, 0.5) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(224, 231, 255, 0.4) 0%, transparent 50%),
        linear-gradient(160deg, #f8fafc 0%, #e2e8f0 30%, #f1f5f9 60%, #e8edf5 100%) !important;
    color: #1e293b !important;
}
[data-theme] .login-page input[type="email"],
[data-theme] .login-page input[type="password"],
[data-theme] .login-page input[type="text"] {
    background: white !important;
    color: #1e293b !important;
}
[data-theme] .login-page input::placeholder {
    color: #94a3b8 !important;
}
[data-theme] .login-page label {
    color: #475569 !important;
}
[data-theme] .login-page h2,
[data-theme] .login-page h3,
[data-theme] .login-page h4 {
    color: #1e293b !important;
}
[data-theme] .login-logo-medi {
    background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #334155 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
[data-theme] .login-logo-sist {
    background: linear-gradient(135deg, #2563eb 0%, #3b82f6 40%, #60a5fa 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
[data-theme] .login-page .sub-title {
    color: #94a3b8 !important;
}
[data-theme] .login-page .login-logo-letter {
    color: white !important;
    -webkit-text-fill-color: white !important;
}
[data-theme] .login-page .remember-text {
    color: #475569 !important;
}
[data-theme] .login-page .remember-box {
    background: #fff !important;
    border-color: #d1d5db !important;
}
[data-theme] .login-page .remember-me input[type="checkbox"]:checked + .remember-box {
    background: linear-gradient(135deg, #2563eb, #3b82f6) !important;
    border-color: #2563eb !important;
}
[data-theme] .login-page .forgot-password-link {
    color: #3b82f6 !important;
}
[data-theme] .login-page .glass-card {
    background: rgba(255, 255, 255, 0.85) !important;
    border-color: rgba(226, 232, 240, 0.6) !important;
    color: #1e293b !important;
}
[data-theme] .login-page .btn-modern-login {
    color: white !important;
}
[data-theme] .login-page .login-message {
    color: #d9534f !important;
}
/* Login — forgot password card */
[data-theme] .login-page .forgot-card {
    background: white !important;
    color: #1e293b !important;
}
[data-theme] .login-page .forgot-card input {
    background: white !important;
    border-color: #e2e8f0 !important;
    color: #1e293b !important;
}
[data-theme] .login-page .forgot-card label {
    color: #475569 !important;
}

/* Sistem seçim popup — her zaman light */
[data-theme] .sistem-secim-overlay {
    background: linear-gradient(135deg, rgba(15,23,42,0.92), rgba(30,41,59,0.95)) !important;
}
[data-theme] .sistem-secim-panel {
    background: #fff !important;
    color: #1e293b !important;
}
[data-theme] .ss-header {
    background: linear-gradient(135deg, #0ea5e9 0%, #6366f1 50%, #a855f7 100%) !important;
    color: white !important;
}
[data-theme] .ss-header h2 {
    color: white !important;
}
[data-theme] .ss-header p {
    color: rgba(255,255,255,0.9) !important;
}
[data-theme] .ss-header p strong {
    color: white !important;
}
[data-theme] .ss-card {
    background: #fff !important;
    border-color: #e2e8f0 !important;
    color: #1e293b !important;
}
[data-theme] .ss-card:hover {
    border-color: #93c5fd !important;
}
[data-theme] .ss-title {
    color: #1e293b !important;
}
[data-theme] .ss-desc {
    color: #64748b !important;
}

/* ═══════════════════════════════════════════════════════════════
   YÖNETİM PANELİ TEMA DESTEĞİ
   Yönetim alt sayfaları (.ym-page) artık ana temayı kullanır.
   Yönetim dashboard (.yonetim-wrapper) kendi koyu stilini korur.
   ═══════════════════════════════════════════════════════════════ */

/* 1) Yönetim alt sayfaları — ana temayı kullanır, ek sıfırlama yok */

/* 2) Genel element'ler — tema değişkenlerini kullanır */
[data-theme] .ym-page input,
[data-theme] .ym-page textarea,
[data-theme] .ym-page select {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}

[data-theme] .ym-page select option {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

[data-theme] .ym-page label {
    color: var(--t-text-muted) !important;
}

[data-theme] .ym-page table {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

[data-theme] .ym-page table th,
[data-theme] .ym-page table thead th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

[data-theme] .ym-page table td {
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

[data-theme] .ym-page table thead {
    background: var(--t-hover) !important;
}

[data-theme] .ym-page table tr:hover td {
    background: var(--t-hover) !important;
}

/* 3) Yönetim sidebar araması — app.css sonunda "YÖNETİM SIDEBAR SEARCH"
      bloğunda (aside.yms/aside.ymm) en yüksek specificity ile işleniyor. */

/* 4) Yönetim alt sayfaları arka planı — temayı kullanır */
[data-theme] .ym-page {
    background: var(--t-body) !important;
    color: var(--t-text) !important;
    min-height: var(--app-height, 100vh) !important;
}
/* Yönetim açıkken body seçilen tema ile uyumlu kalsın */
[data-theme]:has(.ym-page) body,
[data-theme]:has(.yonetim-wrapper) body {
    background: var(--t-body) !important;
    color: var(--t-text) !important;
}
[data-theme]:has(.login-page) body {
    background: var(--t-body) !important;
    color: var(--t-text) !important;
}
/* Yönetim dashboard — tüm temalarda orijinal koyu gradient'i koru */
[data-theme] .yonetim-wrapper {
    color: inherit !important;
}

/* Yönetim dashboard scrollbar'ları — koyu arka planla uyumlu */
.main-content:has(.yonetim-wrapper) {
    scrollbar-color: rgba(99,102,241,0.25) #151e2e;
}
.main-content:has(.yonetim-wrapper)::-webkit-scrollbar-track { background: #151e2e; }
.main-content:has(.yonetim-wrapper)::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.25); }
.main-content:has(.yonetim-wrapper)::-webkit-scrollbar-thumb:hover { background: rgba(99,102,241,0.45); }

/* Yönetim dashboard iç panelleri */
.ym-online-panel-body,
.ym-info-list,
.ym-birim-grid { scrollbar-width: thin; scrollbar-color: rgba(99,102,241,0.15) transparent; }
.ym-online-panel-body::-webkit-scrollbar,
.ym-info-list::-webkit-scrollbar,
.ym-birim-grid::-webkit-scrollbar { width: 3px; }
.ym-online-panel-body::-webkit-scrollbar-track,
.ym-info-list::-webkit-scrollbar-track,
.ym-birim-grid::-webkit-scrollbar-track { background: transparent; }
.ym-online-panel-body::-webkit-scrollbar-thumb,
.ym-info-list::-webkit-scrollbar-thumb,
.ym-birim-grid::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.15); border-radius: 20px; }
.ym-online-panel-body::-webkit-scrollbar-thumb:hover,
.ym-info-list::-webkit-scrollbar-thumb:hover,
.ym-birim-grid::-webkit-scrollbar-thumb:hover { background: rgba(99,102,241,0.30); }
/* Dashboard içindeki başlık, metin, tablo — scoped CSS'e bırak */
[data-theme] .yonetim-wrapper h2,
[data-theme] .yonetim-wrapper h3,
[data-theme] .yonetim-wrapper h4 {
    color: inherit !important;
}
[data-theme] .yonetim-wrapper table,
[data-theme] .yonetim-wrapper table th,
[data-theme] .yonetim-wrapper table td,
[data-theme] .yonetim-wrapper table thead {
    background: inherit !important;
    color: inherit !important;
    border-color: inherit !important;
}
[data-theme] .yonetim-wrapper table tbody tr:hover {
    background: inherit !important;
}
[data-theme] .yonetim-wrapper label {
    color: inherit !important;
}
[data-theme] .yonetim-wrapper input,
[data-theme] .yonetim-wrapper select,
[data-theme] .yonetim-wrapper textarea {
    background: inherit !important;
    border-color: inherit !important;
    color: inherit !important;
}

/* ═══════════════════════════════════════════════════════
   GLOBAL KOLON FİLTRE SİSTEMİ (cfp-*)
   Tüm yönetim sayfalarında ortak kullanılır.
   ═══════════════════════════════════════════════════════ */
.th-sf { cursor: pointer; user-select: none; position: relative; transition: all 0.15s; }
.th-sf:hover { color: #6366f1; background: #f0f4ff; }
.th-sf.filtered { color: #4f46e5; background: #eef2ff; }
.th-sf.filterable { border-bottom: 2.5px solid #c7d2fe; }
.th-sf.filterable.filtered { border-bottom-color: #6366f1; }

.col-filter-banner {
    display: flex; align-items: center; gap: 12px; padding: 8px 16px; margin-bottom: 8px;
    background: #eef2ff; border: 1.5px solid #c7d2fe; border-radius: 8px;
    font-size: 0.82rem; font-weight: 600; color: #4f46e5;
}
.col-filter-banner button {
    margin-left: auto; border: 1px solid #a5b4fc; background: white; color: #4f46e5;
    padding: 3px 10px; border-radius: 6px; font-size: 0.75rem; font-weight: 600; cursor: pointer;
}
.col-filter-banner button:hover { background: #eef2ff; }

.cfp-backdrop {
    position: fixed; inset: 0;
    z-index: 9000; background: rgba(0,0,0,0.15);
    display: flex; align-items: center; justify-content: center;
}
.cfp-dropdown {
    position: relative; z-index: 1;
    background: white; border-radius: 14px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.18), 0 0 0 1px rgba(0,0,0,0.04);
    width: 320px; max-width: calc(100vw - 32px); max-height: 70vh; overflow: hidden;
    display: flex; flex-direction: column;
    animation: cfp-in 0.15s ease-out;
    text-transform: none; letter-spacing: 0; font-weight: 400;
}
@keyframes cfp-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.cfp-header {
    padding: 12px 16px 10px; display: flex; align-items: center; justify-content: space-between;
    border-bottom: 1px solid #f1f5f9;
}
.cfp-title { font-weight: 800; font-size: 0.88rem; color: #1e293b; }
.cfp-close {
    border: none; background: #f1f5f9; color: #64748b; width: 24px; height: 24px;
    border-radius: 6px; cursor: pointer; font-size: 0.78rem; font-weight: 700;
    display: flex; align-items: center; justify-content: center; transition: all 0.15s;
}
.cfp-close:hover { background: #fef2f2; color: #dc2626; }
.cfp-sort { padding: 10px 16px; }
.cfp-sort-btn {
    width: 100%; padding: 8px 14px; border: 1.5px solid #e2e8f0; border-radius: 8px;
    background: #f8fafc; font-size: 0.8rem; font-weight: 700; color: #475569;
    cursor: pointer; transition: all 0.15s; text-align: left;
}
.cfp-sort-btn:hover { border-color: #a5b4fc; background: #eef2ff; color: #4f46e5; }
.cfp-sort-btn.asc:hover { border-color: #86efac; background: #f0fdf4; color: #16a34a; }
.cfp-sort-btn.desc:hover { border-color: #fca5a5; background: #fef2f2; color: #dc2626; }
.cfp-divider { height: 1px; background: #e2e8f0; margin: 0; }
.cfp-search-wrap { padding: 10px 16px 6px; }
.cfp-search {
    width: 100%; padding: 7px 12px; border: 1.5px solid #e2e8f0; border-radius: 8px;
    font-size: 0.8rem; outline: none; box-sizing: border-box; transition: border 0.15s;
}
.cfp-search:focus { border-color: #6366f1; box-shadow: 0 0 0 3px rgba(99,102,241,0.08); }
.cfp-actions { display: flex; gap: 4px; padding: 4px 16px 6px; }
.cfp-actions button {
    flex: 1; padding: 5px 8px; border: 1.5px solid #e2e8f0; border-radius: 6px;
    background: white; font-size: 0.72rem; font-weight: 700; color: #475569;
    cursor: pointer; transition: all 0.15s;
}
.cfp-actions button:hover { background: #eef2ff; border-color: #a5b4fc; color: #4f46e5; }
.cfp-list { flex: 1; overflow-y: auto; padding: 2px 0 6px; max-height: 200px; }
.cfp-item {
    display: flex; align-items: center; gap: 8px; padding: 5px 16px;
    cursor: pointer; font-size: 0.82rem; color: #334155; transition: background 0.1s;
}
.cfp-item:hover { background: #f8fafc; }
.cfp-item input[type="checkbox"] {
    width: 15px; height: 15px; accent-color: #6366f1; cursor: pointer; flex-shrink: 0;
}
.cfp-empty { padding: 12px; text-align: center; color: #94a3b8; font-size: 0.8rem; }

@media (max-width: 768px) {
    .cfp-dropdown { width: 90vw; }
}

/* 5) Yönetim sidebar — seçilen tema (masaüstü .yms) */
[data-theme] .yms {
    background: var(--t-sidebar) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .yms-header {
    background: var(--t-sidebar-head) !important;
}
[data-theme] .yms-link {
    color: color-mix(in srgb, var(--t-topbar-text) 88%, transparent) !important;
}
[data-theme] .yms-link:hover {
    background: rgba(255,255,255,0.1) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .yms-link.active {
    background: var(--t-sidebar-active) !important;
    color: #fff !important;
}
[data-theme] .yms-title {
    background: linear-gradient(135deg,
        var(--t-topbar-text) 0%,
        color-mix(in srgb, var(--t-topbar-text) 75%, var(--t-sidebar-active)) 55%,
        var(--t-sidebar-active) 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
[data-theme] .yms-subtitle {
    color: color-mix(in srgb, var(--t-topbar-text) 58%, transparent) !important;
}

/* 6) Yönetim mobil sidebar — seçilen tema ile uyumlu */
[data-theme] .ymm {
    background: var(--t-sidebar) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .ymm-header {
    background: var(--t-sidebar-head) !important;
}
[data-theme] .ymm-link {
    color: color-mix(in srgb, var(--t-topbar-text) 88%, transparent) !important;
}
[data-theme] .ymm-link:hover {
    background: rgba(255,255,255,0.1) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .ymm-link.active {
    background: var(--t-sidebar-active) !important;
    color: #fff !important;
}

/* 7) Yönetim topbar — tema gradient ve metin */
[data-theme] .ym-page .ym-topbar {
    background: var(--t-topbar) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .ym-page .ym-topbar h2 {
    color: var(--t-topbar-text) !important;
}

/* 8) Yönetim topbar kullanıcı butonu */
[data-theme] .ym-page .ym-topbar-ubtn {
    border-color: color-mix(in srgb, var(--t-topbar-text) 22%, transparent) !important;
    color: var(--t-topbar-text) !important;
}

/* ═══════════════════════════════════════════════════════
   KULLANICI SAYFALARI — GLOBAL TEMA UYUMU
   Tüm .page-container içindeki ortak elemanları tema
   değişkenleriyle override eder.
   ═══════════════════════════════════════════════════════ */

/* ── Scrollbar tema ── */

/* Global şık scrollbar — varsayılan (aydınlık) */
::-webkit-scrollbar {
    width: 7px; height: 7px;
}
::-webkit-scrollbar-track {
    background: transparent;
    margin: 4px 0;
}
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #c7d2fe, #a5b4fc);
    border-radius: 20px;
    border: 1.5px solid transparent;
    background-clip: content-box;
    transition: background 0.3s;
}
::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #818cf8, #6366f1);
    border-radius: 20px;
    border: 1px solid transparent;
    background-clip: content-box;
}
::-webkit-scrollbar-corner {
    background: transparent;
}
/* Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: #c7d2fe transparent;
}

/* ── Aydınlık tema scrollbar ── */
[data-theme="light"] ::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #c7d2fe, #a5b4fc);
    border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box;
}
[data-theme="light"] ::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #818cf8, #6366f1);
    border-radius: 20px; border: 1px solid transparent; background-clip: content-box;
}
[data-theme="light"] { scrollbar-color: #c7d2fe transparent; }

/* ── Koyu temalar scrollbar ── */
[data-theme="dark"] ::-webkit-scrollbar-thumb,
[data-theme="midnight"] ::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #334155, #475569);
    border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box;
}
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover,
[data-theme="midnight"] ::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #64748b, #94a3b8);
    border-radius: 20px; border: 1px solid transparent; background-clip: content-box;
}
[data-theme="dark"],
[data-theme="midnight"] {
    scrollbar-color: #475569 #0f172a;
}

/* ── Açık renkli temalar — accent'e uyumlu scrollbar ── */
[data-theme="steel"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #9fa6b2, #7b8794); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="steel"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #7b8794, #52606d); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="steel"] { scrollbar-color: #9fa6b2 transparent; }

[data-theme="sand"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #fde68a, #fbbf24); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="sand"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #f59e0b, #d97706); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="sand"] { scrollbar-color: #fde68a transparent; }

[data-theme="sunset"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #fed7aa, #fdba74); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="sunset"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #fb923c, #f97316); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="sunset"] { scrollbar-color: #fed7aa transparent; }

[data-theme="rose"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #fecdd3, #fda4af); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="rose"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #fb7185, #f43f5e); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="rose"] { scrollbar-color: #fecdd3 transparent; }

[data-theme="pink"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #fbcfe8, #f9a8d4); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="pink"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #f472b6, #ec4899); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="pink"] { scrollbar-color: #fbcfe8 transparent; }

[data-theme="lavender"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #e9d5ff, #d8b4fe); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="lavender"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #c084fc, #a855f7); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="lavender"] { scrollbar-color: #e9d5ff transparent; }

[data-theme="ocean"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #a5f3fc, #67e8f9); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="ocean"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #22d3ee, #06b6d4); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="ocean"] { scrollbar-color: #a5f3fc transparent; }

[data-theme="mint"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #99f6e4, #5eead4); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="mint"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #2dd4bf, #14b8a6); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="mint"] { scrollbar-color: #99f6e4 transparent; }

[data-theme="forest"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #bbf7d0, #86efac); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="forest"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #4ade80, #22c55e); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="forest"] { scrollbar-color: #bbf7d0 transparent; }

[data-theme="sapphire"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #bfdbfe, #93c5fd); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="sapphire"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #60a5fa, #3b82f6); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="sapphire"] { scrollbar-color: #bfdbfe transparent; }

[data-theme="mocha"] ::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #e8ddd0, #d4c4b0); border-radius: 20px; border: 1.5px solid transparent; background-clip: content-box; }
[data-theme="mocha"] ::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #b8a38e, #9c8570); border-radius: 20px; border: 1px solid transparent; background-clip: content-box; }
[data-theme="mocha"] { scrollbar-color: #e8ddd0 transparent; }

/* ── Kullanıcı sayfası arka plan & metin ── */
[data-theme] .page-container {
    color: var(--t-text) !important;
}

/* ── Genel beyaz arka planlı kartlar / bölümler ── */
[data-theme] .table-responsive,
[data-theme] .detail-section,
[data-theme] .bday-list,
[data-theme] .balance-strip,
[data-theme] .izn-stat-card,
[data-theme] .izn-form-card,
[data-theme] .izn-list-card,
[data-theme] .izn-detay,
[data-theme] .msg-main,
[data-theme] .msg-sidebar,
[data-theme] .hasta-list-card,
[data-theme] .hasta-detail-card,
[data-theme] .ekip-card,
[data-theme] .ekip-table-card,
[data-theme] .hakkimda-card,
[data-theme] .egitim-card,
[data-theme] .rapor-card,
[data-theme] .masraf-table-card,
[data-theme] .masraf-form-card,
[data-theme] .is-table-card,
[data-theme] .is-form-card,
[data-theme] .sistem-secim-panel,
[data-theme] .ss-card {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Tablo başlıkları ── */
[data-theme] .page-container table th,
[data-theme] .page-container .modern-table th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .page-container table thead {
    background: var(--t-hover) !important;
}

/* ── Tablo hücreleri ── */
[data-theme] .page-container table td {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .page-container table tr:hover {
    background: var(--t-hover) !important;
}

/* ── Aktif satır ── */
[data-theme] .page-container .row-active {
    background: var(--t-accent-light) !important;
    outline-color: var(--t-accent) !important;
}

/* ── Input / Select / Textarea ── */
[data-theme] .page-container input:not([type="checkbox"]):not([type="radio"]),
[data-theme] .page-container select,
[data-theme] .page-container textarea {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .page-container input:focus,
[data-theme] .page-container select:focus,
[data-theme] .page-container textarea:focus {
    border-color: var(--t-accent) !important;
}
[data-theme] .page-container input::placeholder,
[data-theme] .page-container textarea::placeholder {
    color: var(--t-text-muted) !important;
}
[data-theme] .page-container select option {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

/* ── Label'lar ── */
[data-theme] .page-container label {
    color: var(--t-text-muted) !important;
}

/* ── Başlıklar ── */
[data-theme] .page-container h2,
[data-theme] .page-container h3,
[data-theme] .page-container h4 {
    color: var(--t-text) !important;
}
/* Personel bilgileri — üst şerit tema gradient'i (--t-topbar); başlık topbar metin rengi */
[data-theme] .page-container .profile-banner h2,
[data-theme] .page-container .profile-info h2 {
    color: var(--t-topbar-text) !important;
}
[data-theme] .page-container .profile-banner .profile-role {
    color: color-mix(in srgb, var(--t-topbar-text) 90%, transparent) !important;
}
/* Ayar paneli başlığı — koyu arka plan üzerinde beyaz kalmalı */
[data-theme] .page-container .ayar-head h3,
[data-theme] .ayar-head h3 {
    color: #fff !important;
}

/* ── List header (koyu arka planlı) — dokunma ── */
[data-theme] .list-header {
    /* Koyu arka plan zaten var, tema değiştirmeye gerek yok */
}

/* ── Search bar input (list-header içindeki) ── */
[data-theme] .list-header .search-bar input {
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,0.2) !important;
}
[data-theme] .list-header .search-bar input::placeholder {
    color: rgba(255,255,255,0.5) !important;
}

/* ── Detail panel / header ── */
[data-theme] .detail-header {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
    border-left-color: var(--t-accent) !important;
}
[data-theme] .detail-header h2 {
    color: var(--t-text) !important;
}
[data-theme] .detail-card {
    border-color: var(--t-card-border) !important;
}
[data-theme] .detail-card h4 {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .d-label { color: var(--t-text-muted) !important; }
[data-theme] .d-value { color: var(--t-text) !important; }
[data-theme] .code-tag {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
[data-theme] .note-text {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}

/* ═══ SAYFA-GENELİ TEMA OVERRIDE'LARI ═══ */

/* Personel-liste ortak bileşenler */
[data-theme] .pl-list-header {
    background: var(--t-hover) !important;
}
[data-theme] .pl-filter-bar {
    background: var(--t-hover) !important;
}
[data-theme] .pl-table thead {
    background: var(--t-hover) !important;
}

/* Masraf sayfası — şablon bar, görüntü section, kaydet paneli */
[data-theme] .sablon-bar {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .sablon-kaydet-panel {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .goruntu-section {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .goruntu-section.has-image {
    background: var(--t-card) !important;
    border-color: var(--t-accent, #86efac) !important;
}
[data-theme] .goruntu-label { color: var(--t-text) !important; }
[data-theme] .goruntu-badge.pending {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* Form section / header / body — tüm sayfalardaki .form-section, .page-header vb. */
[data-theme] .form-section,
[data-theme] .section-card {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .section-header {
    background: var(--t-hover) !important;
    border-bottom-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}

/* Filtre banner */
[data-theme] .col-filter-banner {
    background: var(--t-accent-light) !important;
    border-color: var(--t-card-border) !important;
}

/* Butonlar temaya uyum */
[data-theme] .btn-new,
[data-theme] .btn-cancel {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

/* Patient tag / genel tag */
[data-theme] .patient-tag,
[data-theme] .pl-tag {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* İstatistik kartları (yonetim-liste.css ym-stat) */
[data-theme] .ym-stat:not(.active):not(.green):not(.blue):not(.red):not(.purple):not(.teal):not(.indigo):not(.orange) {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-stat-lbl { color: var(--t-text-muted) !important; }
[data-theme] .ym-stat.active .ym-stat-lbl { color: var(--t-text) !important; }

/* Tüm input alanları genel tema */
[data-theme] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]),
[data-theme] textarea,
[data-theme] select {
    background: var(--t-input-bg, var(--t-card)) !important;
    border-color: var(--t-input-border, var(--t-card-border)) !important;
    color: var(--t-text) !important;
}

/* Ödenen section / modal popup'lar */
[data-theme] .odenen-modal,
[data-theme] .odenen-content {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .odenen-header {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
[data-theme] .odenen-table thead {
    background: var(--t-hover) !important;
}
[data-theme] .odenen-table th {
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table td {
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .close-detail {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text-muted) !important;
}

/* ── Doğum günleri ── */
[data-theme] .bday-list h3 { color: var(--t-text) !important; }
[data-theme] .bday-row {
    background: var(--t-hover) !important;
    border-color: transparent !important;
}
[data-theme] .bday-row:hover {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .bday-name { color: var(--t-text) !important; }
[data-theme] .bday-birim { color: var(--t-text-muted) !important; }
[data-theme] .bday-day { color: var(--t-text) !important; }
[data-theme] .countdown-days {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .empty-text { color: var(--t-text-muted) !important; }

/* ── Masraf bakiye strip ── */
[data-theme] .bal-item.highlight {
    background: var(--t-hover) !important;
}
[data-theme] .bal-label { color: var(--t-text-muted) !important; }
[data-theme] .bal-divider { background: var(--t-card-border) !important; }

/* ── İzin kartları ── */
[data-theme] .izn-stat-card,
[data-theme] .izn-form-card,
[data-theme] .izn-list-card,
[data-theme] .izn-detay {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .btn-new {
    background: var(--t-card) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Mesaj kutusu ── */
[data-theme] .msg-main,
[data-theme] .msg-sidebar {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Dashboard — sistem seçimi ── */
[data-theme] .sistem-secim-panel {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}
[data-theme] .ss-card {
    border-color: var(--t-card-border) !important;
    background: var(--t-card) !important;
}
[data-theme] .ss-title { color: var(--t-text) !important; }
[data-theme] .ss-desc { color: var(--t-text-muted) !important; }

/* ── Masraf / İş girişi görüntü yükleme alanları ── */
[data-theme] .upload-zone,
[data-theme] .file-zone,
[data-theme] .dropzone,
[data-theme] .image-upload-area {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text-muted) !important;
}

/* ── Genel metin renkleri ── */
[data-theme] .page-container .card-label,
[data-theme] .page-container .card-title { color: var(--t-text) !important; }
[data-theme] .page-container .card-desc,
[data-theme] .page-container .card-subtitle { color: var(--t-text-muted) !important; }

/* ── Filtre butonları (kullanıcı sayfaları) ── */
[data-theme] .page-container .filter-btn:not(.active),
[data-theme] .page-container .tab-btn:not(.active) {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text-muted) !important;
}
/* Hakkımda sekme çubuğu — şeffaf pasif sekme (kart zemini üzerinde) */
[data-theme] .page-container .profile-card > .tab-bar .tab-btn:not(.active) {
    background: transparent !important;
    border-color: transparent !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .page-container .profile-card > .tab-bar .tab-btn:hover:not(.active) {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
[data-theme] .page-container .profile-card > .tab-bar .tab-btn.active {
    color: var(--t-accent) !important;
    border-bottom-color: var(--t-accent) !important;
    background: linear-gradient(to bottom, var(--t-accent-light), transparent) !important;
}
[data-theme] .page-container .profile-card > .tab-bar {
    border-bottom-color: var(--t-card-border) !important;
}

/* ── Popup / Modal (genel) ── */
[data-theme] .modal-content,
[data-theme] .popup-content,
[data-theme] .modal-body {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Hakkımda kartları ── */
[data-theme] .info-card,
[data-theme] .info-section {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .info-label { color: var(--t-text-muted) !important; }
[data-theme] .info-value { color: var(--t-text) !important; }

/* ═══════════════════════════════════════════════════════
   YÖNETİM SAYFALARI — GLOBAL TEMA UYUMU
   .ym-page içindeki ortak elemanları tema değişkenleriyle
   override eder. Scoped CSS'lerdeki beyaz arka planları kapsar.
   ═══════════════════════════════════════════════════════ */

/* ── Yönetim sayfa kartları / panelleri ── */
[data-theme] .ym-page .ym-section {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ym-topbar-dropdown {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border: 1px solid var(--t-card-border) !important;
}

/* ── Yönetim modal / popup / panel beyaz arka planları ── */
[data-theme] .ym-page .modal-content,
[data-theme] .ym-page .popup-panel,
[data-theme] .ym-page .edit-panel,
[data-theme] .ym-page .detail-panel,
[data-theme] .ym-page .form-panel,
[data-theme] .ym-page .side-panel,
[data-theme] .ym-page .ym-detail,
[data-theme] .ym-page .ym-edit-panel,
[data-theme] .ym-page .ym-form,
[data-theme] .ym-page .ym-modal-content,
[data-theme] .ym-page .odenen-panel,
[data-theme] .ym-page .cfp-dropdown {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Dark / Gece mavisi temalarda ym-page içindeki kalan beyaz kartlar ──
   Modül ekranlarında hâlâ sabit #fff / white kullanan istatistik ve rozet
   kartlarını toplu olarak tema yüzeyine çek. */
[data-theme="dark"] .ym-page .prsbas-stat,
[data-theme="dark"] .ym-page .prsbas-rozet,
[data-theme="dark"] .ym-page .pv-bsr-rozet,
[data-theme="dark"] .ym-page .stat-card,
[data-theme="dark"] .ym-page .rozet-card,
[data-theme="dark"] .ym-page .ticket-card,
[data-theme="dark"] .ym-page .destek-panel,
[data-theme="dark"] .ym-page .proje-card,
[data-theme="dark"] .ym-page .proje-panel,
[data-theme="dark"] .ym-page .egitim-card,
[data-theme="midnight"] .ym-page .prsbas-stat,
[data-theme="midnight"] .ym-page .prsbas-rozet,
[data-theme="midnight"] .ym-page .pv-bsr-rozet,
[data-theme="midnight"] .ym-page .stat-card,
[data-theme="midnight"] .ym-page .rozet-card,
[data-theme="midnight"] .ym-page .ticket-card,
[data-theme="midnight"] .ym-page .destek-panel,
[data-theme="midnight"] .ym-page .proje-card,
[data-theme="midnight"] .ym-page .proje-panel,
[data-theme="midnight"] .ym-page .egitim-card {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Yönetim filtre butonları ── */
[data-theme] .ym-page .ym-fbtn:not(.active):not(.download):not(.raporlama) {
    background: var(--t-card) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Yönetim dropdown menü ── */
[data-theme] .ym-page .ym-td-item {
    color: var(--t-text) !important;
}
[data-theme] .ym-page .ym-td-item:hover {
    background: var(--t-hover) !important;
    color: var(--t-accent) !important;
}

/* ── Yönetim istatistik kartları metin renkleri ── */
[data-theme] .ym-page .ym-stat:not(.green):not(.blue):not(.red):not(.purple):not(.teal):not(.indigo):not(.orange) .ym-stat-val {
    color: var(--t-text) !important;
}
[data-theme] .ym-page .ym-stat-lbl {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page .ym-stat.active .ym-stat-lbl {
    color: var(--t-text) !important;
}

/* ── Yönetim heading renkleri ── */
[data-theme] .ym-page h2,
[data-theme] .ym-page h3,
[data-theme] .ym-page h4 {
    color: var(--t-text) !important;
}
/* ── Ayar paneli — seçilen tema (koyu temada beyaz kutu / silik metin yok) ── */
[data-theme] .ym-page .ayar-head {
    background: var(--t-topbar) !important;
    color: var(--t-topbar-text) !important;
}
[data-theme] .ym-page .ayar-head h3 {
    color: var(--t-topbar-text) !important;
}
[data-theme] .ym-page .ayar-panel {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}
[data-theme] .ym-page .ayar-sec-title {
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ayar-x {
    color: var(--t-topbar-text) !important;
}
[data-theme] .ym-page .font-btn {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .font-btn:hover {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .ym-page .font-btn.secili {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-accent) 18%, transparent);
}
[data-theme] .ym-page .font-btn .fb-alt {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page .ff-btn {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ff-btn:hover {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .ym-page .ff-btn.secili {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-accent) 18%, transparent);
}
[data-theme] .ym-page .ff-ad {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page .ayar-toggle-etiket strong {
    color: var(--t-text) !important;
}
[data-theme] .ym-page .ayar-toggle-etiket span {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page .ayar-toggle-row {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ayar-link {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ayar-link:hover {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
    transform: translateX(4px);
}
[data-theme] .ym-page .ayar-link-ok {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page .ayar-sifirla {
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .ym-page .ayar-sifirla:hover {
    border-color: #ef4444 !important;
    color: #fecaca !important;
    background: color-mix(in srgb, #ef4444 14%, var(--t-card)) !important;
}
[data-theme] .ym-page .ayar-bilgi-notu {
    background: color-mix(in srgb, var(--t-accent) 16%, var(--t-card)) !important;
    border-color: color-mix(in srgb, var(--t-accent) 40%, var(--t-card-border)) !important;
    color: var(--t-accent) !important;
}

/* ── Yönetim sayfa içi beyaz arka planlı bölümler — geniş kapsam ── */
/* Bu kurallar scoped CSS'lerdeki background:white tanımlarını override eder */
[data-theme] .ym-page .table-responsive,
[data-theme] .ym-page .detail-section,
[data-theme] .ym-page .form-section,
[data-theme] .ym-page .filter-card,
[data-theme] .ym-page .yk-dash-left,
[data-theme] .ym-page .yk-dash-right,
[data-theme] .ym-page .yk-list-card,
[data-theme] .ym-page .yk-edit-panel,
[data-theme] .ym-page .yk-detail-panel,
[data-theme] .ym-page .ev-left,
[data-theme] .ym-page .ev-right,
[data-theme] .ym-page .ev-card,
[data-theme] .ym-page .ev-tabs,
[data-theme] .ym-page .odeme-card,
[data-theme] .ym-page .odeme-panel,
[data-theme] .ym-page .odeme-form,
[data-theme] .ym-page .masraf-card,
[data-theme] .ym-page .izin-card,
[data-theme] .ym-page .izin-panel,
[data-theme] .ym-page .hasta-card,
[data-theme] .ym-page .hasta-panel,
[data-theme] .ym-page .is-card,
[data-theme] .ym-page .is-panel,
[data-theme] .ym-page .ekp-card,
[data-theme] .ym-page .ekp-panel,
[data-theme] .ym-page .sb-card,
[data-theme] .ym-page .sb-panel,
[data-theme] .ym-page .egitim-card,
[data-theme] .ym-page .destek-card,
[data-theme] .ym-page .personel-card,
[data-theme] .ym-page .log-card,
[data-theme] .ym-page .ym-detail,
[data-theme] .ym-page .ym-edit-panel,
[data-theme] .ym-page .ym-form,
[data-theme] .ym-page .ym-modal-content {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Yönetim tablo hover, input, label — scoped CSS override ── */
[data-theme] .ym-page .ym-table tr:hover,
[data-theme] .ym-page table tr:hover {
    background: var(--t-hover) !important;
}
[data-theme] .ym-page input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not(.ar-input):not(aside.ymm-panel *):not(aside.yms *),
[data-theme] .ym-page select:not(aside.ymm-panel *):not(aside.yms *),
[data-theme] .ym-page textarea:not(aside.ymm-panel *):not(aside.yms *) {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .ym-page input::placeholder,
[data-theme] .ym-page textarea::placeholder {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page label {
    color: var(--t-text-muted) !important;
}
[data-theme] .ym-page select option {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

/* ═══════════════════════════════════════════════════════
   KULLANICI SAYFALARI — KAPSAMLI TEMA UYUMU
   .page-container, .pl-*, form alanları, card'lar, tablo
   başlıkları, boş kayıt mesajları vb. hardcoded renkleri
   tema değişkenleriyle override eder.
   ═══════════════════════════════════════════════════════ */

/* ── Genel kart arka planları ── */
[data-theme] .page-container .form-section,
[data-theme] .page-container .card,
[data-theme] .page-container .list-card,
[data-theme] .page-container .panel,
[data-theme] .page-container .section,
[data-theme] .page-container .stat-card,
[data-theme] .page-container .summary-card,
[data-theme] .page-container .form-card {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}

/* ── Tablo üstü header (list-header, section-header) ── */
[data-theme] .page-container .list-header {
    background: var(--t-sidebar, #1e293b) !important;
    color: var(--t-topbar-text, white) !important;
}
[data-theme] .page-container .section-header {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .page-container .form-header {
    background: transparent !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}

/* ── Tablo wrap ── */
[data-theme] .page-container .table-responsive {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Tablo th/td ── */
[data-theme] .page-container table thead {
    background: var(--t-hover) !important;
}
[data-theme] .page-container table th {
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .page-container table td {
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .page-container table tr:hover {
    background: var(--t-hover) !important;
}

/* ── Boş kayıt mesajı ── */
[data-theme] .page-container .empty-row,
[data-theme] .pl-table .empty-row,
[data-theme] .ym-table .empty-row {
    background: var(--t-hover) !important;
}

/* ── İstatistik kartları (genel) ── */
[data-theme] .page-container .stat-item,
[data-theme] .page-container .stat-box {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .page-container .stat-value { color: var(--t-text) !important; }
[data-theme] .page-container .stat-label { color: var(--t-text-muted) !important; }

/* ── Readonly badge / tag ── */
[data-theme] .page-container .readonly-badge {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* ── İzin sayfası ── */
[data-theme] .izn-stat-grid .izn-stat-item {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .izn-stat-val { color: var(--t-text) !important; }
[data-theme] .izn-stat-lbl { color: var(--t-text-muted) !important; }
[data-theme] .izn-tab:not(.active) {
    background: var(--t-card) !important;
    color: var(--t-text-muted) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Eğitim sayfası ── */
[data-theme] .egitim-card,
[data-theme] .egitim-section,
[data-theme] .video-card,
[data-theme] .sinav-card,
[data-theme] .sertifika-card {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Ekipman sayfası ── */
[data-theme] .ekip-card,
[data-theme] .ekip-detail,
[data-theme] .ekip-panel {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Destek taleplerim ── */
[data-theme] .destek-card,
[data-theme] .destek-form,
[data-theme] .destek-detail {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .destek-msg {
    background: var(--t-hover) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}

/* ── İş girişi sayfası ── */
[data-theme] .is-card,
[data-theme] .is-form-panel,
[data-theme] .is-detail-panel {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .day-tag {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* ── Mesaj kutusu ── */
[data-theme] .msg-item:hover,
[data-theme] .msg-item.active {
    background: var(--t-hover) !important;
}
[data-theme] .msg-sender { color: var(--t-text) !important; }
[data-theme] .msg-preview { color: var(--t-text-muted) !important; }
[data-theme] .msg-compose,
[data-theme] .msg-reply-area {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}

/* ── Placeholder renkleri ── */
[data-theme] .page-container input::placeholder,
[data-theme] .page-container textarea::placeholder {
    color: var(--t-text-muted) !important;
}

/* ── Genel metin renkleri ── */
[data-theme] .page-container h1,
[data-theme] .page-container h2,
[data-theme] .page-container h3,
[data-theme] .page-container h4 {
    color: var(--t-text) !important;
}
[data-theme] .page-container label:not(.cfp-item) {
    color: var(--t-text-muted) !important;
}

/* ── Select option dropdown ── */
[data-theme] .page-container select option {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}

/* ── Disabled input ── */
[data-theme] .page-container input:disabled,
[data-theme] .page-container textarea:disabled,
[data-theme] .page-container select:disabled {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}

/* ── Ayarlar sayfası ── */
[data-theme] .settings-card,
[data-theme] .setting-box {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .box-header {
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .box-body { color: var(--t-text) !important; }
[data-theme] .box-desc { color: var(--t-text-muted) !important; }
[data-theme] .s-input {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .contact-row { color: var(--t-text) !important; }

/* ═══════════════════════════════════════════════════════
   AYDINLIK TEMA — GÜZEL GRADİENT
   Sadece light tema için gradient uygulanır.
   Diğer temalar var(--t-hover) ile kendi renklerini kullanır.
   ═══════════════════════════════════════════════════════ */

/* Tablo üstü başlık alanları */
[data-theme="light"] .pl-list-header {
    background: linear-gradient(135deg, #f8fafc, #eff6ff) !important;
}

/* İzin listesi başlık */
[data-theme="light"] .izn-liste-header {
    background: linear-gradient(135deg, #f8fafc, #eff6ff) !important;
}

/* Filtre barları */
[data-theme="light"] .pl-filter-bar {
    background: linear-gradient(135deg, #fafbff, #f1f5ff) !important;
}

/* Tablo thead */
[data-theme="light"] .pl-table thead,
[data-theme="light"] .page-container table thead {
    background: linear-gradient(135deg, #f8fafc, #f1f5f9) !important;
}

/* Masraf — şablon bar */
[data-theme="light"] .sablon-bar {
    background: linear-gradient(135deg, #faf5ff, #eff6ff) !important;
}

/* Masraf — şablon kaydet paneli */
[data-theme="light"] .sablon-kaydet-panel {
    background: linear-gradient(135deg, #faf5ff, #f5f3ff) !important;
    border-color: #c4b5fd !important;
}

/* Görüntü section */
[data-theme="light"] .goruntu-section {
    background: linear-gradient(135deg, #f8fafc, #f0f4ff) !important;
    border-color: #e2e8f0 !important;
}
[data-theme="light"] .goruntu-section.has-image {
    background: linear-gradient(135deg, #f0fdf4, #ecfdf5) !important;
    border-color: #86efac !important;
}

/* Section header / form header */
[data-theme="light"] .page-container .section-header {
    background: linear-gradient(135deg, #f8fafc, #eff6ff) !important;
}
[data-theme="light"] .page-container .form-header {
    background: transparent !important;
}

/* Boş kayıt mesajı */
[data-theme="light"] .pl-table .empty-row,
[data-theme="light"] .ym-table .empty-row {
    background: linear-gradient(135deg, #fef2f2, #fff5f5) !important;
}

/* İzin hak ediş itemler */
[data-theme="light"] .izn-hakedis-item {
    background: linear-gradient(135deg, #f8fafc, #f0f9ff) !important;
    border-color: #e2e8f0 !important;
}

/* Destek mesajları */
[data-theme="light"] .destek-msg {
    background: linear-gradient(135deg, #f8fafc, #f0f4ff) !important;
}

/* İstatistik kartları */
[data-theme="light"] .ym-stat:not(.active):not(.green):not(.blue):not(.red):not(.purple):not(.teal):not(.indigo):not(.orange) {
    background: linear-gradient(135deg, #ffffff, #f8fafc) !important;
}

/* ═══════════════════════════════════════════════════════
   SIDEBAR SEARCH — EN SON OVERRIDE
   Global input kurallarını yenmesi için
   dosyanın en sonunda, en yüksek specificity ile yazılır.
   Specificity: (0,5,2) → global (0,4,1) yener
   ═══════════════════════════════════════════════════════ */
.app-container aside.modern-sidebar .sidebar-search input[type="search"],
.app-container aside.modern-sidebar form.sidebar-search input {
    background: rgba(255,255,255,0.12) !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    color: #fff !important;
}
.app-container aside.modern-sidebar .sidebar-search input[type="search"]::placeholder,
.app-container aside.modern-sidebar form.sidebar-search input::placeholder {
    color: rgba(255,255,255,0.45) !important;
}
.app-container aside.modern-sidebar .sidebar-search input[type="search"]:focus,
.app-container aside.modern-sidebar form.sidebar-search input:focus {
    background: rgba(255,255,255,0.18) !important;
    border-color: var(--t-sidebar-active, #38bdf8) !important;
    box-shadow: 0 0 0 2px rgba(255,255,255,0.08) !important;
}

/* ═══════════════════════════════════════════════════════
   YÖNETİM SIDEBAR SEARCH — kural artık yonetim-sidebar.css
   içinde; duplicate tanımlar kaldırıldı.
   ═══════════════════════════════════════════════════════ */

/* ── Bugünkü Ziyaretler Banner (Dashboard) — tema uyumu ── */
[data-theme] .ziyaret-banner {
    background: linear-gradient(135deg, var(--t-accent-light), color-mix(in srgb, var(--t-accent-light) 80%, var(--t-accent) 20%)) !important;
    border-color: color-mix(in srgb, var(--t-accent) 30%, var(--t-card-border) 70%) !important;
}
[data-theme] .ziyaret-banner:hover {
    box-shadow: 0 4px 16px color-mix(in srgb, var(--t-accent) 15%, transparent) !important;
}
[data-theme] .zb-header {
    color: var(--t-accent) !important;
}
[data-theme] .zb-item {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .zb-item.blue {
    border-left-color: var(--t-accent) !important;
}
[data-theme] .zb-merkez {
    color: var(--t-text) !important;
}
[data-theme] .zb-hasta {
    color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .zb-saat {
    color: var(--t-text-muted) !important;
}
/* Gecikmiş banner — dark/midnight tema uyumu */
[data-theme="dark"] .ziyaret-banner-gecikmis,
[data-theme="midnight"] .ziyaret-banner-gecikmis {
    background: linear-gradient(135deg, rgba(127,29,29,0.25) 0%, rgba(153,27,27,0.2) 100%) !important;
    border-color: rgba(248,113,113,0.35) !important;
}
[data-theme="dark"] .ziyaret-banner-gecikmis .zb-header,
[data-theme="midnight"] .ziyaret-banner-gecikmis .zb-header {
    color: #fca5a5 !important;
}
[data-theme="dark"] .zb-item.red,
[data-theme="midnight"] .zb-item.red {
    background: rgba(127,29,29,0.3) !important;
    border-color: rgba(248,113,113,0.3) !important;
    border-left-color: #f87171 !important;
}
/* Gecikmiş buton — temalarda accent rengine geç (varsayılan kırmızıyı override et) */
[data-theme] .ziyaret-banner-gecikmis .zb-is-btn {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
}
[data-theme] .ziyaret-banner-gecikmis .zb-is-btn:hover {
    background: var(--t-accent) !important;
    color: white !important;
}
[data-theme="dark"] .zb-item.green,
[data-theme="midnight"] .zb-item.green {
    background: rgba(22,101,52,0.2) !important;
    border-left-color: #4ade80 !important;
}

/* ── Dashboard Logo & Marka — tema uyumu ── */
[data-theme] .dashboard-wrapper .logo-icon {
    background: linear-gradient(135deg, var(--t-sidebar), var(--t-accent), var(--t-sidebar-active)) !important;
    box-shadow: 0 4px 20px color-mix(in srgb, var(--t-accent) 25%, transparent) !important;
}
/* Aydınlık temada logo — login sayfasıyla aynı canlı gradient (MEDİ koyu lacivert, SİST mavi) */
[data-theme="light"] .dashboard-wrapper .logo-icon {
    background: linear-gradient(135deg, #1e3a5f 0%, #2563eb 50%, #3b82f6 100%) !important;
    box-shadow: 0 4px 20px rgba(37,99,235,0.25) !important;
}
[data-theme="light"] .dashboard-wrapper .logo-pulse {
    background: linear-gradient(135deg, rgba(37,99,235,0.15), rgba(59,130,246,0.1)) !important;
}
[data-theme="light"] .dashboard-wrapper .logo-medi {
    background: linear-gradient(135deg, #0f172a 0%, #1e3a5f 50%, #334155 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
    color: transparent !important;
}
[data-theme="light"] .dashboard-wrapper .logo-sist {
    background: linear-gradient(135deg, #2563eb 0%, #3b82f6 40%, #60a5fa 100%) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
[data-theme="light"] .dashboard-wrapper .logo-letter {
    text-shadow: none !important;
    opacity: 1 !important;
}
[data-theme] .dashboard-wrapper .logo-pulse {
    background: linear-gradient(135deg, color-mix(in srgb, var(--t-accent) 15%, transparent), color-mix(in srgb, var(--t-sidebar-active) 10%, transparent)) !important;
}
[data-theme] .dashboard-wrapper .logo-medi {
    color: var(--t-text) !important;
    -webkit-text-fill-color: var(--t-text) !important;
}
[data-theme] .dashboard-wrapper .logo-sist {
    background: linear-gradient(90deg, var(--t-accent), var(--t-sidebar-active)) !important;
    -webkit-background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    background-clip: text !important;
}
[data-theme] .dashboard-wrapper .system-subtitle {
    color: var(--t-text-muted) !important;
}
[data-theme] .dashboard-wrapper .icon-box {
    background: color-mix(in srgb, var(--t-accent) 8%, transparent) !important;
}
[data-theme] .dashboard-wrapper .menu-card:hover .icon-box {
    background: color-mix(in srgb, var(--t-accent) 15%, transparent) !important;
}
[data-theme] .dashboard-wrapper .menu-card:hover {
    border-color: var(--t-accent) !important;
    box-shadow: 0 16px 40px color-mix(in srgb, var(--t-accent) 15%, transparent) !important;
    background: linear-gradient(145deg, var(--t-accent-light), color-mix(in srgb, var(--t-accent-light) 80%, var(--t-accent) 20%)) !important;
}
[data-theme] .dashboard-wrapper .menu-card.has-unread {
    border-color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
/* Duyuru şeridi: orta alanın hafif accent zemini — .ticker-label üzerinde
   accent background kullanmayın; etiket rengi de accent olduğu için yazı görünmez oluyordu. */
[data-theme] .dashboard-wrapper .ticker-content {
    background: color-mix(in srgb, var(--t-accent) 9%, var(--t-card)) !important;
}
[data-theme] .dashboard-wrapper .online-avatar-placeholder {
    background: linear-gradient(135deg, var(--t-accent), var(--t-sidebar-active)) !important;
}
[data-theme] .dashboard-wrapper .qm-header {
    background: linear-gradient(135deg, var(--t-accent), var(--t-sidebar-active)) !important;
}

/* ── Dashboard Bildirim Butonu — header-btn ile aynı görünüm ── */
.dashboard-wrapper .dash-notif-btn {
    background: var(--t-hover, #f8fafc) !important;
    color: var(--t-text, #475569) !important;
    border: 1px solid var(--t-card-border, #e2e8f0) !important;
    border-radius: 10px !important;
}
.dashboard-wrapper .dash-notif-btn:hover {
    background: var(--t-accent-light, #e2e8f0) !important;
    border-color: var(--t-card-border, #e2e8f0) !important;
    transform: scale(1.05);
}
/* Sadece KARANLIK temalarda override — aydınlık temada Dashboard.razor.css'teki
   orijinal renkler (mor gradient header-btn, açık mavi btn-user vb.) korunur. */
[data-theme="dark"] .dashboard-wrapper .dash-notif-btn,
[data-theme="midnight"] .dashboard-wrapper .dash-notif-btn {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme="dark"] .dashboard-wrapper .dash-notif-btn:hover,
[data-theme="midnight"] .dashboard-wrapper .dash-notif-btn:hover {
    background: var(--t-accent-light) !important;
}
[data-theme="dark"] .dashboard-wrapper .header-btn,
[data-theme="midnight"] .dashboard-wrapper .header-btn {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme="dark"] .dashboard-wrapper .header-btn:hover,
[data-theme="midnight"] .dashboard-wrapper .header-btn:hover {
    background: var(--t-accent-light) !important;
}
/* btn-user karanlık temada — gradient yerine soft accent zemin */
[data-theme="dark"] .btn-user,
[data-theme="midnight"] .btn-user {
    background: var(--t-accent-light) !important;
    color: var(--t-accent) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme="dark"] .btn-user .ku-presence-inline,
[data-theme="midnight"] .btn-user .ku-presence-inline {
    color: var(--t-text-muted, #94a3b8) !important;
}
[data-theme="dark"] .btn-user .dash-user-chevron.topbar-user-chevron-wrap,
[data-theme="midnight"] .btn-user .dash-user-chevron.topbar-user-chevron-wrap {
    color: color-mix(in srgb, var(--t-accent) 45%, transparent) !important;
}

/* ── Masraf Filtre Butonları — tema uyumu ── */
[data-theme] .filter-btn:hover {
    background: var(--t-hover) !important;
}
[data-theme] .filter-btn:not(.waiting):not(.arrived):not(.reported):not(.approved):not(.paid).active {
    background: var(--t-sidebar) !important;
}
[data-theme] .filter-btn.approved.active {
    background: var(--t-accent) !important;
}

/* ── MasrafGirisi Sayfası — tema uyumu ── */
[data-theme] .list-header {
    background: var(--t-sidebar) !important;
}
[data-theme] .list-header.green {
    background: #166534 !important;
}
[data-theme] .form-header {
    border-left-color: var(--t-accent) !important;
}
[data-theme] .form-header h2 {
    color: var(--t-text) !important;
}
[data-theme] .group label {
    color: var(--t-text-muted) !important;
}
[data-theme] .modern-table tr:hover {
    background: var(--t-hover) !important;
}
[data-theme] .count-badge {
    background: var(--t-accent) !important;
}
[data-theme] .btn-save {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 85%, white)) !important;
    box-shadow: 0 2px 8px color-mix(in srgb, var(--t-accent) 20%, transparent) !important;
}
[data-theme] .btn-save:hover {
    box-shadow: 0 8px 20px color-mix(in srgb, var(--t-accent) 30%, transparent) !important;
}
[data-theme] .btn-new {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
[data-theme] .btn-new:hover {
    background: var(--t-card-border) !important;
}
[data-theme] input:checked + .slider {
    background-color: var(--t-accent) !important;
}
[data-theme] .sabit-veri-box {
    background: var(--t-accent-light) !important;
    border-color: color-mix(in srgb, var(--t-accent) 30%, var(--t-card-border)) !important;
}
[data-theme] .sabit-label {
    color: var(--t-accent) !important;
}
[data-theme] .sablon-chip:hover {
    border-color: var(--t-accent) !important;
    color: var(--t-accent) !important;
    background: var(--t-accent-light) !important;
}
[data-theme] .sablon-save-btn {
    background: linear-gradient(135deg, var(--t-accent), color-mix(in srgb, var(--t-accent) 75%, #8b5cf6)) !important;
}
[data-theme] .sablon-kaydet-head {
    color: var(--t-accent) !important;
}
[data-theme] .row-active {
    background: var(--t-accent-light) !important;
    outline-color: var(--t-accent) !important;
}
[data-theme] .avans-title {
    color: var(--t-text) !important;
}
[data-theme] .avans-header:hover {
    background: var(--t-hover) !important;
}
[data-theme] .avans-card {
    border-color: var(--t-card-border) !important;
    background: var(--t-hover) !important;
}
[data-theme] .avans-tutar {
    color: var(--t-text) !important;
}
[data-theme] .avans-card-desc {
    color: var(--t-text-muted) !important;
}
[data-theme] .avans-card-proje {
    color: var(--t-accent) !important;
}
[data-theme] .odenen-header {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-header h3 {
    color: var(--t-text) !important;
}
[data-theme] .odenen-close {
    border-color: var(--t-card-border) !important;
    background: var(--t-hover) !important;
}
[data-theme] .odenen-section-title {
    color: var(--t-text) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table th {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .odenen-table td {
    border-bottom-color: var(--t-card-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .odenen-table tr:hover td {
    background: var(--t-hover) !important;
}
[data-theme] .odenen-footer {
    border-top-color: var(--t-card-border) !important;
}

/* ── Takvim Etkinlik Popup — tema uyumu ── */
[data-theme] .tkv-popup {
    background: var(--t-card) !important;
    color: var(--t-text) !important;
}
[data-theme] .tkv-popup-header {
    border-bottom-color: var(--t-card-border) !important;
}
[data-theme] .tkv-popup-header h3 {
    color: var(--t-text) !important;
}
[data-theme] .tkv-popup-footer {
    border-top-color: var(--t-card-border) !important;
}
[data-theme] .tkv-popup-kapat {
    background: var(--t-hover) !important;
    color: var(--t-text-muted) !important;
}
[data-theme] .tkv-popup-kapat:hover {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
[data-theme] .tkv-btn.primary {
    background: var(--t-accent) !important;
    color: white !important;
}
[data-theme] .tkv-btn.secondary {
    background: var(--t-hover) !important;
    color: var(--t-text) !important;
}
[data-theme] .tkv-btn.secondary:hover {
    background: var(--t-card-border) !important;
}
[data-theme] .tkv-btn.danger {
    background: #fef2f2 !important;
    color: #dc2626 !important;
}
[data-theme] .tkv-btn.danger:hover {
    background: #fee2e2 !important;
}
[data-theme] .tkv-btn.warning {
    background: #fefce8 !important;
    color: #ca8a04 !important;
}
[data-theme] .tkv-btn.warning:hover {
    background: #fef9c3 !important;
}
[data-theme] .tkv-form-group label {
    color: var(--t-text-muted) !important;
}
[data-theme] .tkv-form-input {
    background: var(--t-input-bg) !important;
    border-color: var(--t-input-border) !important;
    color: var(--t-text) !important;
}
[data-theme] .tkv-form-input:focus {
    border-color: var(--t-accent) !important;
}
[data-theme] .tkv-renk-btn.secili {
    border-color: var(--t-text) !important;
}
[data-theme] .tkv-popup-body {
    color: var(--t-text) !important;
}
[data-theme] .tkv-detay-aksyon.tkv-edit:hover {
    background: var(--t-accent-light) !important;
}
[data-theme] .tkv-detay-aksyon.tkv-go:hover {
    background: var(--t-accent-light) !important;
}
[data-theme] .tkv-ozet-item {
    background: var(--t-card) !important;
    border-color: var(--t-card-border) !important;
}
[data-theme] .tkv-ozet-label {
    color: var(--t-text-muted) !important;
}

/* ═══════════════════════════════════════════════════════
   TEMA İSTİSNALARI — yalnızca tam ekran özel akışlar
   (Login, sistem seçimi, yeniden bağlan) için değişkenleri
   okunabilir açık palete sabitle. Yönetim (.ym-page, sidebar)
   artık üstteki [data-theme] paletini miras alır.
   ═══════════════════════════════════════════════════════ */
[data-theme] .login-page,
[data-theme] .sistem-secim-overlay {
    --t-body: #f1f5f9;
    --t-card: #ffffff;
    --t-card-border: #e2e8f0;
    --t-text: #1e293b;
    --t-text-muted: #64748b;
    --t-sidebar: #1e293b;
    --t-sidebar-head: #0f172a;
    --t-sidebar-active: #0ea5e9;
    --t-topbar: linear-gradient(135deg, #1e293b, #334155);
    --t-topbar-text: #f8fafc;
    --t-input-bg: #fcfdfe;
    --t-input-border: #cbd5e1;
    --t-accent: #6366f1;
    --t-accent-light: #eef2ff;
    --t-hover: #f8fafc;
}

/* Yönetim yan sidebar araması — nihai kural app.css L5223 civarındaki
   "YÖNETİM SIDEBAR SEARCH" bloğunda (aside.yms/aside.ymm ile en yüksek
   specificity'de) tanımlıdır. Aşağıdaki [data-theme] bazlı kural kaldırıldı
   çünkü var(--t-sidebar) kullanımı tüm temada inputu sidebar arka planına
   eşitleyerek görünmez hale getiriyordu. */

/* ── Yönetim sekmeleri — tema koruma kuralları yonetim-liste.css'te ── */

/* ── Ayar overlay — yönetimde backdrop-filter düzeltme ── */
/* .ym-page topbar'ı z-index:100 + backdrop-filter kullanır,
   bu yeni stacking context oluşturur. Overlay topbar içinden
   render olduğu için backdrop-filter doğru çalışmaz.
   Çözüm: overlay'i topbar stacking context'inden çıkarmak yerine
   yönetim sayfalarında overlay'e sabit koyu arka plan veririz. */

/* ═══════════════════════════════════════════════════════
   DROP ZONE — GLOBAL DRAG VALIDATION STİLLERİ
   drop-zone.js tarafından eklenen .dz-valid / .dz-invalid
   class'ları ve .dz-drag-msg mesaj elementi.
   ═══════════════════════════════════════════════════════ */

/* Geçerli dosya sürüklendiğinde — yeşil kenarlık */
.dz-valid {
    border-color: #10b981 !important;
    border-style: solid !important;
    background: rgba(16, 185, 129, 0.06) !important;
    box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.12), 0 8px 30px rgba(16, 185, 129, 0.15) !important;
    transform: scale(1.01);
    transition: all 0.2s ease;
}

/* Geçersiz dosya sürüklendiğinde — kırmızı kenarlık */
.dz-invalid {
    border-color: #ef4444 !important;
    border-style: solid !important;
    background: rgba(239, 68, 68, 0.06) !important;
    box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.12), 0 8px 30px rgba(239, 68, 68, 0.12) !important;
    transform: scale(1.01);
    transition: all 0.2s ease;
}

/* Drag mesajı (otomatik oluşturulur) */
.dz-drag-msg {
    display: none;
    width: 100%;
    text-align: center;
    padding: 8px 14px;
    font-size: 0.78rem;
    font-weight: 700;
    border-radius: 0 0 10px 10px;
    box-sizing: border-box;
    animation: dzMsgSlide 0.2s ease;
}

.dz-valid .dz-drag-msg {
    background: rgba(16, 185, 129, 0.1);
    color: #059669;
}

.dz-invalid .dz-drag-msg {
    background: rgba(239, 68, 68, 0.1);
    color: #dc2626;
}

@keyframes dzMsgSlide {
    from { opacity: 0; transform: translateY(-4px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ═══════════════════════════════════════════
   MOBİL INPUT / ARAMA KUTUSU KÜÇÜLTME
   Tüm sayfalarda geçerli global kurallar
   ═══════════════════════════════════════════ */
@media (max-width: 768px) {
    .page-container input[type="search"],
    .page-container input[type="text"],
    .page-container input[type="date"],
    .page-container input[type="number"],
    .page-container input[type="email"],
    .page-container input[type="tel"],
    .page-container select,
    .page-container textarea {
        font-size: 0.82rem !important;
        padding: 7px 12px !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
    .page-container input[type="search"] {
        height: 34px !important;
    }
    .page-container { overflow-x: hidden; }
}
@media (max-width: 480px) {
    .page-container input[type="search"],
    .page-container input[type="text"],
    .page-container input[type="date"],
    .page-container input[type="number"],
    .page-container input[type="email"],
    .page-container input[type="tel"],
    .page-container select,
    .page-container textarea {
        font-size: 0.78rem !important;
        padding: 6px 10px !important;
    }
    .page-container input[type="search"] {
        height: 32px !important;
    }
}

/* ═══ PWA INSTALL BANNER ═══ */
#pwa-install-banner {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(120px);
    z-index: 99999;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 18px;
    background: var(--t-card, #fff);
    border: 1px solid var(--t-card-border, #e2e8f0);
    border-radius: 16px;
    box-shadow: 0 12px 40px rgba(0,0,0,0.18);
    max-width: 420px;
    width: calc(100% - 32px);
    opacity: 0;
    transition: transform 0.35s cubic-bezier(0.16,1,0.3,1), opacity 0.35s ease;
}
#pwa-install-banner.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}
#pwa-install-banner.hiding {
    transform: translateX(-50%) translateY(120px);
    opacity: 0;
}
.pwa-banner-icon {
    font-size: 1.8rem;
    flex-shrink: 0;
}
.pwa-banner-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.pwa-banner-text strong {
    font-size: 0.92rem;
    color: var(--t-text, #1e293b);
}
.pwa-banner-text span {
    font-size: 0.78rem;
    color: var(--t-text-muted, #64748b);
}
.pwa-banner-install {
    flex-shrink: 0;
    padding: 8px 18px;
    background: linear-gradient(135deg, #4f46e5, #6366f1);
    color: #fff;
    border: none;
    border-radius: 10px;
    font-weight: 700;
    font-size: 0.82rem;
    cursor: pointer;
    transition: transform 0.15s, box-shadow 0.15s;
}
.pwa-banner-install:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 16px rgba(99,102,241,0.35);
}
.pwa-banner-close {
    position: absolute;
    top: -6px;
    right: -6px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    border: 1px solid var(--t-card-border, #e2e8f0);
    background: var(--t-card, #fff);
    color: var(--t-text-muted, #94a3b8);
    font-size: 0.72rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.15s;
    line-height: 1;
    padding: 0;
}
.pwa-banner-close:hover {
    background: #fee2e2;
    color: #ef4444;
    border-color: #fca5a5;
}

/* ═══ PWA INSTALL TIP (kapatınca gösterilen bilgi notu) ═══ */
#pwa-install-tip {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(80px);
    z-index: 99999;
    padding: 12px 20px;
    background: var(--t-sidebar, #1e293b);
    color: #e2e8f0;
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.25);
    max-width: 400px;
    width: calc(100% - 32px);
    font-size: 0.8rem;
    line-height: 1.5;
    text-align: center;
    cursor: pointer;
    opacity: 0;
    transition: transform 0.4s cubic-bezier(0.16,1,0.3,1), opacity 0.4s ease;
}
#pwa-install-tip.show {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}
#pwa-install-tip.hiding {
    transform: translateX(-50%) translateY(80px);
    opacity: 0;
}
#pwa-install-tip b {
    color: #93c5fd;
}

/* ═══════════════════════════════════════════
   GLOBAL SAĞ TIK MENÜSÜ
   ═══════════════════════════════════════════ */
.gctx-overlay {
    position: fixed; inset: 0; z-index: 2147483646;
    cursor: default;
}
.gctx-menu {
    position: fixed; z-index: 2147483647;
    background: var(--t-card, #fff);
    border: 1px solid var(--t-card-border, #e2e8f0);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.14), 0 2px 8px rgba(0,0,0,0.06);
    min-width: 220px; max-width: 280px;
    max-height: calc(var(--app-height, 100vh) - 16px);
    overflow-y: auto;
    padding: 5px 0;
    opacity: 0;
    backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}
.gctx-menu.gctx-ready {
    animation: gctx-pop 0.14s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes gctx-pop {
    from { opacity: 0; transform: scale(0.92); }
    to { opacity: 1; transform: scale(1); }
}
.gctx-item {
    display: flex; align-items: center; gap: 10px;
    width: 100%; padding: 8px 14px;
    border: none; background: none;
    font-size: 0.84rem; font-weight: 600;
    color: var(--t-text, #1e293b);
    cursor: pointer; transition: all 0.12s;
    text-align: left; white-space: nowrap;
    font-family: inherit;
}
.gctx-item:hover {
    background: color-mix(in srgb, var(--t-accent, #6366f1) 10%, transparent);
    color: var(--t-accent, #6366f1);
}
.gctx-icon {
    font-size: 0.92rem; width: 22px; height: 22px; text-align: center; flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center;
}
.gctx-icon svg.ms-icon { width: 18px; height: 18px; display: block; filter: drop-shadow(0 1px 1px rgba(0,0,0,0.15)); }
.gctx-shortcut {
    margin-left: auto;
    font-size: 0.64rem; font-weight: 600;
    color: var(--t-text-muted, #94a3b8);
    opacity: 0.65; padding-left: 12px;
}
.gctx-badge {
    margin-left: auto;
    background: var(--t-accent, #6366f1); color: white;
    font-size: 0.62rem; font-weight: 800;
    padding: 1px 7px; border-radius: 8px;
    min-width: 16px; text-align: center;
}
.gctx-sep {
    height: 1px; margin: 4px 10px;
    background: var(--t-card-border, #e2e8f0);
}
.gctx-danger {
    color: #ef4444 !important;
}
.gctx-danger:hover {
    background: rgba(239,68,68,0.08) !important;
    color: #dc2626 !important;
}

/* Yönetim paneli teması */
.gctx-yonetim {
    background: #1e293b;
    border-color: rgba(14,165,233,0.25);
    box-shadow: 0 8px 32px rgba(0,0,0,0.35), 0 2px 8px rgba(0,0,0,0.15);
}
.gctx-yonetim .gctx-item {
    color: rgba(255,255,255,0.85);
}
.gctx-yonetim .gctx-item:hover {
    background: rgba(14,165,233,0.15);
    color: #38bdf8;
}
.gctx-yonetim .gctx-sep {
    background: rgba(255,255,255,0.1);
}
.gctx-yonetim .gctx-shortcut {
    color: rgba(255,255,255,0.35);
}
.gctx-yonetim .gctx-badge {
    background: #0ea5e9;
}
.gctx-yonetim .gctx-danger {
    color: #fca5a5 !important;
}
.gctx-yonetim .gctx-danger:hover {
    background: rgba(239,68,68,0.2) !important;
    color: #fecaca !important;
}

/* Dark tema uyumu */
[data-theme="dark"] .gctx-menu {
    box-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 2px 8px rgba(0,0,0,0.2);
}

/* ═══════════════════════════════════════════════════
   DOC-VIEWER — Global stiller (doc-viewer.js)
   ═══════════════════════════════════════════════════ */

/* Loading */
.doc-loading {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 60px 20px; color: #64748b; gap: 14px;
}
.doc-loading-spinner {
    width: 44px; height: 44px; border-radius: 50%;
    border: 4px solid #e2e8f0; border-top-color: var(--t-accent, #6366f1);
    animation: docSpin 0.8s linear infinite;
}
@keyframes docSpin { to { transform: rotate(360deg); } }
.doc-loading p { font-weight: 700; font-size: 0.92rem; margin: 0; color: var(--t-text, #334155); }
.doc-loading-sub { font-size: 0.78rem; color: var(--t-text-muted, #94a3b8); }

/* Empty */
.doc-empty {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 50px 20px; gap: 8px;
}
.doc-empty span { font-size: 2.5rem; }
.doc-empty p { font-weight: 700; color: #94a3b8; margin: 0; }

/* Error Card */
.doc-error-card {
    display: flex; flex-direction: column; align-items: center;
    padding: 36px 24px; gap: 16px; text-align: center;
}
.doc-error-icon {
    width: 64px; height: 64px; border-radius: 50%;
    background: linear-gradient(135deg, #fef2f2, #fee2e2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem; box-shadow: 0 4px 12px rgba(239,68,68,0.1);
}
.doc-error-body h4 {
    margin: 0 0 6px; font-weight: 800; font-size: 1rem; color: var(--t-text, #1e293b);
}
.doc-error-detail {
    margin: 0; font-size: 0.82rem; color: var(--t-text-muted, #94a3b8); font-weight: 600;
    max-width: 360px; line-height: 1.5;
    background: var(--t-hover, #f8fafc); padding: 8px 14px; border-radius: 8px;
    border: 1px solid var(--t-card-border, #e2e8f0);
}
.doc-error-actions {
    display: flex; gap: 10px; flex-wrap: wrap; justify-content: center;
}
.doc-error-download {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 22px; border-radius: 10px;
    background: linear-gradient(135deg, var(--t-accent, #6366f1), #818cf8); color: white;
    font-weight: 700; font-size: 0.88rem; text-decoration: none;
    box-shadow: 0 4px 14px rgba(99,102,241,0.25); transition: all 0.2s;
}
.doc-error-download:hover {
    transform: translateY(-2px); box-shadow: 0 6px 20px rgba(99,102,241,0.35);
}
.doc-error-retry {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 22px; border-radius: 10px;
    background: var(--t-card, white); color: var(--t-text, #475569);
    font-weight: 700; font-size: 0.88rem;
    border: 1.5px solid var(--t-card-border, #e2e8f0); cursor: pointer; transition: all 0.2s;
}
.doc-error-retry:hover {
    border-color: var(--t-accent, #6366f1); color: var(--t-accent, #6366f1);
    transform: translateY(-2px);
}

/* DOCX */
.docx-wrapper {
    padding: 20px; max-height: 600px; overflow-y: auto;
}
.docx-wrapper table { border-collapse: collapse; width: 100%; }
.docx-wrapper table td,
.docx-wrapper table th {
    border: 1px solid var(--t-card-border, #e2e8f0); padding: 6px 10px;
}

/* XLSX */
.xlsx-tabs {
    display: flex; gap: 4px; padding: 8px 12px;
    background: var(--t-hover, #f8fafc); border-bottom: 1px solid var(--t-card-border, #e2e8f0);
    overflow-x: auto; flex-wrap: nowrap;
}
.xlsx-tab {
    padding: 6px 14px; border: 1px solid var(--t-card-border, #e2e8f0); border-radius: 6px;
    background: var(--t-card, white); font-size: 0.8rem; font-weight: 700; color: var(--t-text-muted, #64748b);
    cursor: pointer; white-space: nowrap; transition: all 0.2s;
}
.xlsx-tab:hover { border-color: var(--t-accent, #6366f1); color: var(--t-accent, #6366f1); }
.xlsx-tab.active {
    background: var(--t-accent, #6366f1); color: white; border-color: var(--t-accent, #6366f1);
}
.xlsx-sheet-area { max-height: 500px; overflow: auto; }
.xlsx-table-wrap table {
    border-collapse: collapse; width: 100%; font-size: 0.82rem;
}
.xlsx-table-wrap td,
.xlsx-table-wrap th {
    border: 1px solid var(--t-card-border, #e2e8f0); padding: 5px 8px; white-space: nowrap;
}
.xlsx-table-wrap th {
    background: var(--t-hover, #f1f5f9); font-weight: 700; color: var(--t-text, #334155);
}

/* ═══ CAROUSEL (PPTX & PDF) ═══ */
.doc-carousel {
    display: flex; flex-direction: column;
    border: 1.5px solid var(--t-card-border, #e2e8f0);
    border-radius: 14px; overflow: hidden;
    background: var(--t-card, #ffffff);
    box-shadow: 0 2px 12px rgba(0,0,0,0.04);
}
.doc-carousel-header {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px;
    background: linear-gradient(135deg, var(--t-accent-light, #f0f9ff), color-mix(in srgb, var(--t-accent, #6366f1) 6%, white));
    border-bottom: 1.5px solid var(--t-card-border, #e2e8f0);
}
.doc-carousel-icon {
    width: 38px; height: 38px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem;
    background: var(--t-card, white);
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    border: 1px solid var(--t-card-border, #e2e8f0);
    flex-shrink: 0;
}
.doc-carousel-title {
    flex: 1; font-weight: 800; font-size: 0.92rem;
    color: var(--t-text, #1e293b);
    min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.doc-carousel-badge {
    padding: 5px 14px; border-radius: 20px;
    background: var(--t-card, white); font-size: 0.75rem;
    font-weight: 700; color: var(--t-accent, #6366f1);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
    border: 1px solid color-mix(in srgb, var(--t-accent, #6366f1) 15%, transparent);
    white-space: nowrap; flex-shrink: 0;
}
.doc-carousel-body {
    display: flex; align-items: stretch;
    min-height: 420px; position: relative;
}
.doc-carousel-arrow {
    width: 52px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    background: var(--t-hover, #f8fafc); border: none; cursor: pointer;
    font-size: 1.1rem; color: var(--t-text-muted, #64748b);
    transition: all 0.25s ease;
    position: relative;
}
.doc-carousel-arrow::after {
    content: '';
    position: absolute;
    inset: 12px 8px;
    border-radius: 10px;
    background: transparent;
    transition: all 0.25s ease;
}
.doc-carousel-arrow:hover:not(:disabled)::after {
    background: color-mix(in srgb, var(--t-accent, #6366f1) 10%, transparent);
}
.doc-carousel-arrow:hover:not(:disabled) {
    color: var(--t-accent, #6366f1);
}
.doc-carousel-arrow:active:not(:disabled)::after {
    background: color-mix(in srgb, var(--t-accent, #6366f1) 18%, transparent);
}
.doc-carousel-arrow:disabled {
    opacity: 0.25; cursor: not-allowed;
}
.doc-carousel-arrow.prev {
    border-right: 1px solid var(--t-card-border, #e2e8f0);
}
.doc-carousel-arrow.next {
    border-left: 1px solid var(--t-card-border, #e2e8f0);
}
.doc-carousel-area {
    flex: 1; display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 20px; overflow: hidden;
    min-width: 0;
}
.doc-carousel-slide {
    width: 100%; display: flex; flex-direction: column;
    align-items: center; gap: 16px;
}
.doc-carousel-footer {
    display: flex; align-items: center; justify-content: center;
    padding: 12px 20px; gap: 10px;
    background: var(--t-hover, #f8fafc); border-top: 1.5px solid var(--t-card-border, #e2e8f0);
}
.doc-carousel-indicator {
    font-size: 0.82rem; font-weight: 700; color: var(--t-text-muted, #64748b);
    padding: 3px 14px; border-radius: 20px;
    background: var(--t-card, white);
    border: 1px solid var(--t-card-border, #e2e8f0);
    box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* Slide images */
.carousel-slide-images {
    display: flex; flex-wrap: wrap; gap: 12px;
    justify-content: center; width: 100%;
}
.carousel-slide-images img {
    max-width: 100%; max-height: 380px;
    border-radius: 8px; object-fit: contain;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
/* Slide text */
.carousel-slide-text {
    width: 100%; padding: 12px 20px;
    background: var(--t-hover, #f8fafc); border-radius: 10px;
    border: 1px solid var(--t-card-border, #e2e8f0);
}
.carousel-slide-text p {
    margin: 6px 0; font-size: 0.92rem;
    color: var(--t-text, #1e293b); line-height: 1.7;
}
/* PDF canvas */
.carousel-pdf-wrap {
    display: flex; justify-content: center; width: 100%;
}
.carousel-pdf-wrap canvas {
    max-width: 100%; height: auto !important;
    border-radius: 6px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
/* Empty slide */
.carousel-empty {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    padding: 40px 20px; gap: 8px; color: var(--t-text-muted, #94a3b8);
}
.carousel-empty span { font-size: 2rem; }
.carousel-empty p { font-size: 0.85rem; font-style: italic; margin: 0; }

/* Doc-render container */
.doc-render-container {
    border-radius: 12px; overflow: hidden;
    border: 1px solid var(--t-card-border, #e2e8f0);
    background: var(--t-card, #fff);
    min-height: 300px;
}

@media (max-width: 768px) {
    .doc-carousel-arrow { width: 40px; font-size: 1rem; }
    .doc-carousel-header { padding: 10px 14px; gap: 8px; }
    .doc-carousel-title { font-size: 0.84rem; }
    .doc-carousel-badge { font-size: 0.7rem; padding: 4px 10px; }
    .doc-carousel-area { padding: 12px; }
    .doc-carousel-body { min-height: 300px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   RTL DESTEĞI — Arapça (ar) için sağdan-sola yerleşim
   <html dir="rtl"> olduğunda otomatik aktive olur (App.razor)
   ═══════════════════════════════════════════════════════════════════════ */
[dir="rtl"] {
    text-align: right;
}

/* ── KULLANICI SIDEBAR — sağa sabitlensin ── */
[dir="rtl"] .modern-sidebar {
    left: auto !important;
    right: 0 !important;
    border-right: none;
    border-left: 1px solid var(--t-card-border, #e2e8f0);
}

/* Ana içerik alanı — sidebar sağda olduğu için margin sola değil sağa olmalı */
[dir="rtl"] .main-content.pushed       { margin-left: 0 !important; margin-right: 260px; }
[dir="rtl"] .main-content.mini-pushed  { margin-left: 0 !important; margin-right: 64px; }
[dir="rtl"] .main-content.no-sidebar   { margin-left: 0 !important; margin-right: 0; }
[dir="rtl"] .main-content { transition: margin-right 0.25s ease; }

/* Mobilde sidebar tam ekran açıldığında - margin sıfır kalsın */
@media (max-width: 767px) {
    [dir="rtl"] .main-content.pushed,
    [dir="rtl"] .main-content.mini-pushed { margin-right: 0 !important; }
}

/* ── YÖNETİM SIDEBAR — sağa sabitlensin ── */
[dir="rtl"] .yms { left: auto !important; right: 0 !important; }
[dir="rtl"] .yms-expanded { box-shadow: -4px 0 24px rgba(0,0,0,0.25); }
[dir="rtl"] .yms-overlay { left: 0 !important; right: 260px !important; }
[dir="rtl"] .ymm-panel { left: auto !important; right: 0 !important; }

/* Yönetim sayfaları içerik margin'i — sidebar sağda olduğu için */
[dir="rtl"] .ym-page { margin-left: 0 !important; margin-right: 64px; transition: margin-right 0.25s cubic-bezier(0.16,1,0.3,1); }
@media (max-width: 767px) {
    [dir="rtl"] .ym-page { margin-right: 0 !important; }
}

/* ── TABLO ── */
[dir="rtl"] .ym-table th, [dir="rtl"] .ym-table td { text-align: right; }

/* ── FORM ALANLARI ── */
[dir="rtl"] .ym-input, [dir="rtl"] input, [dir="rtl"] select, [dir="rtl"] textarea { text-align: right; direction: rtl; }
[dir="rtl"] input[type="email"], [dir="rtl"] input[type="url"], [dir="rtl"] input[type="tel"] { direction: ltr; text-align: left; }
[dir="rtl"] input[type="number"], [dir="rtl"] input[inputmode="decimal"], [dir="rtl"] input[inputmode="numeric"] { direction: ltr; text-align: right; }
[dir="rtl"] input[type="date"], [dir="rtl"] input[type="time"], [dir="rtl"] input[type="datetime-local"] { direction: ltr; text-align: right; }

/* ── DROPDOWN / SELECT ── */
[dir="rtl"] select { background-position: left 0.75rem center; padding-right: 0.75rem; padding-left: 2rem; }

/* ── PILL / BADGE / CHIP ── */
[dir="rtl"] .ym-toolbar-badge, [dir="rtl"] .sidebar-badge, [dir="rtl"] .yms-badge,
[dir="rtl"] .ayar-link-ok { margin-left: 0; margin-right: auto; }

/* ── TOAST — sağdan değil soldan slide ── */
[dir="rtl"] .ym-message, [dir="rtl"] .form-message { right: auto; left: 24px; transform: translateX(-120px); }

/* ── FILTER PANEL ── */
[dir="rtl"] .cfp-dropdown { right: auto; left: 0; }
[dir="rtl"] .cfp-actions { flex-direction: row-reverse; }

/* ── GERİ BUTONU emoji yön değişimi ── */
[dir="rtl"] .ym-back::before { content: "→ "; }

/* ── SAYI/TARİH gösterimi LTR kalmalı ── */
[dir="rtl"] .sl-td-tarih, [dir="rtl"] .td-id, [dir="rtl"] .pf-amount, [dir="rtl"] .muh-tutar { direction: ltr; text-align: right; unicode-bidi: embed; }
[dir="rtl"] time, [dir="rtl"] .sl-td-saat { direction: ltr; unicode-bidi: embed; }

/* ── BİLDİRİM PANELİ ── */
[dir="rtl"] .notif-panel { right: auto !important; left: 0; }
[dir="rtl"] .notif-wrap { direction: rtl; }

/* ── DASHBOARD/POPUP konumları ── */
[dir="rtl"] .ym-popup, [dir="rtl"] .modal { direction: rtl; }
[dir="rtl"] .ym-topbar-dropdown, [dir="rtl"] .ku-topbar-dropdown { right: auto !important; left: 0 !important; }

/* ═══════════════════════════════════════════════════════════════════════
   RTL — LOGIN SAYFASI ve diğer giriş ekranları için ek düzenlemeler
   ═══════════════════════════════════════════════════════════════════════ */

/* Login sayfası — direction RTL */
[dir="rtl"] .login-page,
[dir="rtl"] .login-card,
[dir="rtl"] .login-form,
[dir="rtl"] .reset-password-page,
[dir="rtl"] .reset-card { direction: rtl; }

/* Login dil seçici — sol üstten sağ üste taşı */
[dir="rtl"] .login-dil-dropdown { left: auto !important; right: 14px !important; }
[dir="rtl"] .login-dil-menu     { left: auto !important; right: 0 !important; }

/* Versiyon numarası — sağ üstten sol üste taşı (dil seçicisi ile çakışmasın) */
[dir="rtl"] .login-ver-wrapper  { right: auto !important; left: 15px !important; }

/* Mobilde de aynı flip — küçük ekran breakpoint */
@media (max-width: 480px) {
    [dir="rtl"] .login-ver-wrapper { right: auto !important; left: 12px !important; }
}

/* Form içeriği — text sağa yaslı */
[dir="rtl"] .login-form,
[dir="rtl"] .login-card label,
[dir="rtl"] .login-card .field-label,
[dir="rtl"] .login-card h1,
[dir="rtl"] .login-card h2,
[dir="rtl"] .login-card h3,
[dir="rtl"] .login-card p { text-align: right; }

/* E-posta input LTR kalsın (içerik teknik), şifre RTL */
[dir="rtl"] .login-form input[type="email"],
[dir="rtl"] .login-form input[type="url"],
[dir="rtl"] .login-form input[type="tel"] { direction: ltr; text-align: left; }

[dir="rtl"] .login-form input[type="password"],
[dir="rtl"] .login-form input[type="text"]:not([type="email"]) { direction: rtl; text-align: right; }

/* Şifre göster/gizle göz simgesi — sağdan sola taşı */
[dir="rtl"] .pwd-eye-btn,
[dir="rtl"] .pwd-toggle,
[dir="rtl"] .login-input-eye,
[dir="rtl"] .input-eye-btn,
[dir="rtl"] .password-toggle { right: auto !important; left: 12px !important; }

/* "Beni Hatırla" satırı + Şifremi Unuttum link — yön ters */
[dir="rtl"] .login-remember,
[dir="rtl"] .remember-row,
[dir="rtl"] .login-row,
[dir="rtl"] .login-options-row,
[dir="rtl"] .login-actions-row { flex-direction: row-reverse; }

/* Linkler ve butonlar */
[dir="rtl"] .login-links,
[dir="rtl"] .login-actions,
[dir="rtl"] .login-submit { direction: rtl; }

/* Özel gün şeridi (Login üst banner) — ikon sağa, metin sağa */
[dir="rtl"] .login-ozel-serit { flex-direction: row-reverse; text-align: right; }

/* Brand / logo container ortada kalır */
[dir="rtl"] .login-brand,
[dir="rtl"] .login-logo-wrap,
[dir="rtl"] .login-footer,
[dir="rtl"] .login-version { text-align: center; }

/* Versiyon numarası gibi teknik metinler LTR */
[dir="rtl"] .login-version { direction: ltr; }

/* Reset/Yardım popup'ları */
[dir="rtl"] .reset-popup,
[dir="rtl"] .yardim-popup,
[dir="rtl"] .login-popup { direction: rtl; text-align: right; }

/* === DASHBOARD ve diğer kullanıcı sayfaları için ek RTL düzeltmeleri === */

/* Topbar drawer (mobil hamburger menü) — soldan değil sağdan açılsın */
[dir="rtl"] .ku-drawer { left: auto !important; right: 0 !important; transform: translateX(100%) !important; }
[dir="rtl"] .ku-drawer.open { transform: translateX(0) !important; }

/* Ayarlar paneli (KullaniciTopbar + YonetimAyarlar) */
[dir="rtl"] .ayar-overlay { direction: rtl; }
[dir="rtl"] .ayar-panel  { direction: rtl; text-align: right; }

/* Bildirim paneli pozisyonu — sağa değil sola çakılsın (zaten zaten yukarıda var ama kesinleştir) */
[dir="rtl"] .bildirim-panel { right: auto !important; left: 0 !important; }

/* Toast container — sağdan yerine soldan */
[dir="rtl"] .toast-container,
[dir="rtl"] #toast-container { right: auto !important; left: 24px !important; }

/* Tüm modal popup'lar — text sağa */
[dir="rtl"] .ozk-modal,
[dir="rtl"] .ozk-modal h3,
[dir="rtl"] .ozk-body,
[dir="rtl"] .ozk-desc { text-align: right; direction: rtl; }

/* Sayı, tarih, mail, IBAN gibi teknik içerik LTR kalsın (zaten yukarıda kısmen var, genişletelim) */
[dir="rtl"] .iban-display,
[dir="rtl"] .mail-display,
[dir="rtl"] .phone-display,
[dir="rtl"] .tc-display,
[dir="rtl"] code,
[dir="rtl"] pre,
[dir="rtl"] .monospace { direction: ltr; unicode-bidi: embed; }

/* Mobile menü ipucu (drawer hint) — sağdan değil soldan görünsün */
[dir="rtl"] .ku-peek-hint,
[dir="rtl"] .yms-peek-hint { left: auto !important; right: 0 !important; }

/* Tablo başlık ikonları/oklar — flip */
[dir="rtl"] .ym-table .sort-icon,
[dir="rtl"] .ym-table .filter-icon { transform: scaleX(-1); }

/* Geri (←) butonu sembolü — RTL'de "→" mantığında */
[dir="rtl"] .ym-back svg,
[dir="rtl"] .pj-back-btn svg,
[dir="rtl"] .back-arrow { transform: scaleX(-1); }

/* ═══════════════════════════════════════════════════════════
   MÜSAİTLİK DURUMU (chat presence) — kullanıcı topbar dropdown'u
   ═══════════════════════════════════════════════════════════ */
.ku-presence-section {
    padding: 12px 14px 14px;
    border-bottom: 1px solid var(--t-card-border, #e2e8f0);
    background: linear-gradient(180deg, var(--t-card, #ffffff), color-mix(in srgb, var(--t-accent, #6366f1) 4%, var(--t-card, #ffffff)));
}
.ku-presence-title {
    display: flex;
    align-items: center;
    gap: 7px;
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-weight: 700;
    color: var(--t-text-muted, #64748b);
    margin-bottom: 10px;
}
.ku-presence-title-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    box-shadow: 0 0 0 2px var(--t-card, white), 0 0 0 3px currentColor;
}

/* 2 sütunlu grid — her durum kart şeklinde */
.ku-presence-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
    margin-bottom: 8px;
}
.ku-presence-item {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 8px 10px;
    background: var(--t-card, white);
    border: 1.5px solid var(--t-card-border, #e2e8f0);
    border-radius: 10px;
    color: var(--t-text, #0f172a);
    font-size: 0.82rem;
    font-weight: 600;
    text-align: left;
    cursor: pointer;
    transition: all .15s ease;
    position: relative;
}
.ku-presence-icon {
    font-size: 1.1rem;
    line-height: 1;
    flex-shrink: 0;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.12));
}
.ku-presence-text {
    display: flex;
    flex-direction: column;
    gap: 1px;
    flex: 1;
    min-width: 0;
}
.ku-presence-label {
    font-weight: 700;
    color: var(--t-text, #0f172a);
    line-height: 1.15;
}
.ku-presence-alt {
    font-size: 0.66rem;
    color: var(--t-text-muted, #94a3b8);
    line-height: 1.2;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.ku-presence-check {
    position: absolute;
    top: 4px; right: 6px;
    font-size: 0.7rem;
    font-weight: 800;
    color: white;
    background: var(--ku-pres-accent, #6366f1);
    width: 14px; height: 14px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
}

.ku-presence-item:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.08);
    border-color: color-mix(in srgb, var(--ku-pres-accent, #6366f1) 40%, var(--t-card-border, #e2e8f0));
}
.ku-presence-item.active {
    border-color: var(--ku-pres-accent, #6366f1);
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--ku-pres-accent, #6366f1) 12%, var(--t-card, white)),
        var(--t-card, white));
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--ku-pres-accent, #6366f1) 18%, transparent);
}
.ku-presence-item.active .ku-presence-label { color: var(--ku-pres-accent, #6366f1); }

/* Her durum için renk theme (--ku-pres-accent CSS değişkeni ile) */
.ku-presence-item-musait        { --ku-pres-accent: #16a34a; }
.ku-presence-item-mesgul        { --ku-pres-accent: #d97706; }
.ku-presence-item-rahatsiz_etme { --ku-pres-accent: #dc2626; }
.ku-presence-item-gorunmez      { --ku-pres-accent: #64748b; }

/* Renkli noktalar (4 durum) — küçük dot için (avatar üzeri vs) */
.ku-presence-dot {
    display: inline-block;
    width: 10px; height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    box-shadow: 0 0 0 2px var(--t-card, #ffffff);
}
.ku-presence-musait        { background: #22c55e; color: #16a34a; }
.ku-presence-mesgul        { background: #f59e0b; color: #d97706; }
.ku-presence-rahatsiz_etme { background: #dc2626; color: #dc2626; }
.ku-presence-gorunmez      { background: #94a3b8; color: #64748b; }

/* Durum mesajı satırı */
.ku-presence-msg-add,
.ku-presence-msg-show {
    width: 100%;
    margin-top: 4px;
    padding: 8px 12px;
    background: color-mix(in srgb, var(--t-accent, #6366f1) 5%, var(--t-card, white));
    border: 1px dashed color-mix(in srgb, var(--t-accent, #6366f1) 32%, transparent);
    border-radius: 10px;
    color: var(--t-text-muted, #64748b);
    font-size: 0.78rem;
    font-style: italic;
    cursor: pointer;
    text-align: left;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all .15s;
}
.ku-presence-msg-add:hover,
.ku-presence-msg-show:hover {
    border-color: color-mix(in srgb, var(--t-accent, #6366f1) 50%, transparent);
    background: color-mix(in srgb, var(--t-accent, #6366f1) 10%, var(--t-card, white));
}
.ku-presence-msg-show {
    color: var(--t-text, #0f172a);
    font-style: normal;
    font-weight: 500;
    border-style: solid;
}
.ku-presence-msg-text {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
}
.ku-presence-msg-edit-icon {
    opacity: 0.5;
    font-size: 0.78rem;
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 14px;
    height: 14px;
}
.ku-presence-msg-edit-icon svg { width: 14px; height: 14px; }
.ku-presence-msg-chat-icon,
.ku-presence-msg-add-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    filter: drop-shadow(0 1px 1px rgba(0,0,0,0.1));
}
.ku-presence-msg-chat-icon svg,
.ku-presence-msg-add-icon svg { width: 16px; height: 16px; }
.ku-presence-msg-edit {
    margin-top: 4px;
    display: flex;
    gap: 6px;
}
.ku-presence-msg-input {
    flex: 1;
    padding: 8px 12px;
    background: var(--t-card, #ffffff);
    border: 1.5px solid var(--t-card-border, #cbd5e1);
    border-radius: 8px;
    color: var(--t-text, #0f172a);
    font-size: 0.82rem;
    outline: none;
    transition: border-color .15s, box-shadow .15s;
}
.ku-presence-msg-input:focus {
    border-color: var(--t-accent, #6366f1);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-accent, #6366f1) 18%, transparent);
}
.ku-presence-msg-save {
    padding: 6px 14px;
    background: linear-gradient(135deg, var(--t-accent, #6366f1), color-mix(in srgb, var(--t-accent, #6366f1) 70%, #0f172a));
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 0.78rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 2px 6px color-mix(in srgb, var(--t-accent, #6366f1) 30%, transparent);
}
.ku-presence-msg-save:hover { transform: translateY(-1px); }

/* ═══════════════════════════════════════════════════════════
   YÜZER BUTONLAR — sayfa üzeri overlay'ler (sistem seçim,
   ayarlar paneli, login egitim popup vb.) açıkken gizle.
   Pomodoro FAB, komut paleti FAB ve scroll-top butonu yarı
   şeffaf overlay'in üstünden sızmasın.
   ═══════════════════════════════════════════════════════════ */
body:has(.sistem-secim-overlay) .pmd-fab,
body:has(.sistem-secim-overlay) #scroll-top-btn,
body:has(.sistem-secim-overlay) .kpa-modal-trigger {
    display: none !important;
}


/* ═══════════════════════════════════════════════════════════════════════
   ERİŞİLEBİLİRLİK — Global tercihler (Animasyon azalt / Yüksek kontrast / Kompakt)
   Topbar ayarlarından açılır; <html> üzerindeki data-* ile tüm sisteme uygulanır.
   ═══════════════════════════════════════════════════════════════════════ */

/* ⚡ Animasyonları azalt — tüm geçiş ve animasyon sürelerini minimize eder */
html[data-anim="azalt"] *,
html[data-anim="azalt"] *::before,
html[data-anim="azalt"] *::after {
    animation-duration: 0.001ms !important;
    animation-delay: 0ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    transition-delay: 0ms !important;
    scroll-behavior: auto !important;
}

/* 🔆 Yüksek kontrast — okunurluğu artırır, kenarları belirginleştirir */
html[data-kontrast="yuksek"] {
    --t-card-border: #000;
    --t-text-muted: #1e293b;
}
html[data-kontrast="yuksek"] body { filter: contrast(1.15); }
html[data-kontrast="yuksek"] button,
html[data-kontrast="yuksek"] input,
html[data-kontrast="yuksek"] select,
html[data-kontrast="yuksek"] textarea,
html[data-kontrast="yuksek"] .card,
html[data-kontrast="yuksek"] [class*="-card"],
html[data-kontrast="yuksek"] [class*="-panel"] {
    border: 1.5px solid currentColor !important;
}
html[data-kontrast="yuksek"] a { text-decoration: underline; }
html[data-kontrast="yuksek"] :focus-visible {
    outline: 3px solid #f59e0b !important;
    outline-offset: 2px !important;
}

/* 🎯 Kompakt mod — genel padding/margin/font ölçülerini sıkıştırır */
html[data-yogunluk="kompakt"] body { font-size: 0.92rem; }
html[data-yogunluk="kompakt"] .ku-topbar,
html[data-yogunluk="kompakt"] .ym-header { min-height: 48px; }
html[data-yogunluk="kompakt"] h1 { font-size: 1.5rem; }
html[data-yogunluk="kompakt"] h2 { font-size: 1.2rem; }
html[data-yogunluk="kompakt"] h3 { font-size: 1.05rem; }
html[data-yogunluk="kompakt"] button,
html[data-yogunluk="kompakt"] .ayar-link,
html[data-yogunluk="kompakt"] .ayar-toggle-row { padding-top: 6px; padding-bottom: 6px; }
html[data-yogunluk="kompakt"] td,
html[data-yogunluk="kompakt"] th { padding: 6px 8px !important; }


/* ═══ Bildirim tonu seçici (ayar panelinde) ═══ */
.ton-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0,1fr));
    gap: 6px;
    margin-top: 8px;
}
.ton-btn {
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    padding: 8px 4px;
    border: 1.5px solid var(--t-card-border, #e2e8f0);
    border-radius: 10px;
    background: var(--t-card, #fff);
    color: var(--t-text, #1e293b);
    cursor: pointer;
    transition: all .15s ease;
    font-size: 0.72rem;
}
.ton-btn:hover {
    background: var(--t-hover, #f1f5f9);
    border-color: color-mix(in srgb, var(--t-accent, #6366f1) 35%, var(--t-card-border, #e2e8f0));
}
.ton-btn.secili {
    background: color-mix(in srgb, var(--t-accent, #6366f1) 10%, var(--t-card, #fff));
    border-color: var(--t-accent, #6366f1);
    color: var(--t-accent, #4338ca);
    font-weight: 700;
}
.ton-btn .ton-emoji { font-size: 1.35rem; line-height: 1; }
.ton-btn .ton-ad { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
@media (max-width: 560px) {
    .ton-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}

/* ═══════════════════════════════════════════════════════════
   TANITIM SAYFASI — sayfa scroll garantisi + tema izolasyonu (global)
   Tanitim.razor render edildiğinde JS ile body/html'ye eklenir.
   ═══════════════════════════════════════════════════════════ */
html.tnt-page-active,
body.tnt-page-active {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    height: auto !important;
    min-height: 100vh !important;
    max-height: none !important;
    position: static !important;
    background: #020617 !important;
    color: #e2e8f0 !important;
    /* wheel/touch scroll kesin çalışsın */
    overscroll-behavior: auto !important;
    touch-action: pan-y !important;
}
/* Tanıtım sayfasındayken tüm parent wrapper'ların height/overflow lock'larını kır */
html.tnt-page-active * {
    /* sticky/fixed olan alt elementlere müdahale ETME */
}
html.tnt-page-active .main-content,
html.tnt-page-active.no-scroll,
html.tnt-page-active.no-scroll .main-content,
body.tnt-page-active .main-content,
body.tnt-page-active > div:not(.tnt-root) {
    overflow: visible !important;
    height: auto !important;
    max-height: none !important;
    position: static !important;
}
/* Tanıtım sayfası içindeki tüm metinler - global override koruması */
body.tnt-page-active .tnt-root,
body.tnt-page-active .tnt-root * {
    box-sizing: border-box;
}
body.tnt-page-active .tnt-root h1,
body.tnt-page-active .tnt-root h2,
body.tnt-page-active .tnt-root h3,
body.tnt-page-active .tnt-root h4 {
    color: #fff !important;
}
body.tnt-page-active .tnt-root p,
body.tnt-page-active .tnt-root li,
body.tnt-page-active .tnt-root td,
body.tnt-page-active .tnt-root span {
    color: inherit;
}
/* gradient text korumalı */
body.tnt-page-active .tnt-root .tnt-grad,
body.tnt-page-active .tnt-root .tnt-stat-num,
body.tnt-page-active .tnt-root .tnt-num,
body.tnt-page-active .tnt-root .tnt-mr strong,
body.tnt-page-active .tnt-root .tnt-summary-num,
body.tnt-page-active .tnt-root .tnt-hero-title .tnt-grad {
    -webkit-text-fill-color: transparent !important;
}
/* Tanıtım sayfasındayken section default arka plan rengi yok */
body.tnt-page-active .tnt-root section {
    background: transparent;
}
/* Tanıtım sayfası — özel renk zorlamaları (scoped CSS bypass koruması) */
body.tnt-page-active .tnt-root .tnt-section-head p,
body.tnt-page-active .tnt-root .tnt-feat p,
body.tnt-page-active .tnt-root .tnt-cap p,
body.tnt-page-active .tnt-root .tnt-summary-item p,
body.tnt-page-active .tnt-root .tnt-tech-card p,
body.tnt-page-active .tnt-root .tnt-flow-step p,
body.tnt-page-active .tnt-root .tnt-hero-sub,
body.tnt-page-active .tnt-root .tnt-cta-card p {
    color: #cbd5e1 !important;
}
body.tnt-page-active .tnt-root .tnt-section-head p {
    color: #94a3b8 !important;
}
body.tnt-page-active .tnt-root .tnt-stat-lbl,
body.tnt-page-active .tnt-root .tnt-num-label,
body.tnt-page-active .tnt-root .tnt-mr span,
body.tnt-page-active .tnt-root .tnt-cap-tags span,
body.tnt-page-active .tnt-root .tnt-tech-card p,
body.tnt-page-active .tnt-root .tnt-hero-scroll {
    color: #94a3b8 !important;
}
body.tnt-page-active .tnt-root .tnt-cap-tags span {
    color: #a78bfa !important;
}
body.tnt-page-active .tnt-root strong {
    color: #fff !important;
    font-weight: 700;
}
body.tnt-page-active .tnt-root .tnt-atlas td {
    color: #cbd5e1 !important;
}
body.tnt-page-active .tnt-root .tnt-atlas th {
    color: #fff !important;
}
body.tnt-page-active .tnt-root .tnt-feat-list li,
body.tnt-page-active .tnt-root .tnt-road-item li {
    color: #cbd5e1 !important;
}
body.tnt-page-active .tnt-root .tnt-eyebrow {
    color: #a5b4fc !important;
}
/* ═══════════════════════════════════════════════════════════
   TANITIM SAYFASI — Hata/Giriş ekranları (tnt-gate) merkez konum
   garantisi. body class olmadan da çalışsın diye doğrudan .tnt-gate.
   ═══════════════════════════════════════════════════════════ */
.tnt-gate {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px !important;
    background:
        radial-gradient(circle at 20% 20%, #312e81 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, #0e7490 0%, transparent 50%),
        linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%) !important;
    z-index: 9999 !important;
    overflow: auto !important;
    margin: 0 !important;
}
.tnt-gate-card {
    width: 100% !important;
    max-width: 460px !important;
    margin: auto !important;
    color: #e2e8f0 !important;
}
.tnt-gate h1,
.tnt-gate p {
    text-align: center !important;
}
.tnt-gate-logo,
.tnt-gate-icon-err {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
}
/* ═══════════════════════════════════════════════════════════
   TANITIM SAYFASI — Hata/Giriş kartı: Logo + Medisist marka satırı
   ═══════════════════════════════════════════════════════════ */
.tnt-gate-brand {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 12px !important;
    margin-bottom: 24px !important;
}
.tnt-gate-brand svg {
    flex-shrink: 0;
    filter: drop-shadow(0 6px 16px rgba(99, 102, 241, 0.5));
    border-radius: 10px;
}
.tnt-gate-brand-name {
    font-size: 1.5rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    background: linear-gradient(135deg, #ffffff 0%, #c7d2fe 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    line-height: 1;
}
/* Hata ikonu: ortada, alt boşluğu */
.tnt-gate-icon-err {
    margin: 8px auto 18px !important;
}
.tnt-gate-icon-err svg {
    filter: drop-shadow(0 8px 20px rgba(220, 38, 38, 0.35));
    animation: tntErrPulse 2s ease-in-out infinite;
}
@keyframes tntErrPulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.05); }
}
/* Kart içi başlık ve metin renk garantisi */
.tnt-gate-card h1 {
    margin: 0 0 8px !important;
    font-size: 1.8rem !important;
    font-weight: 800 !important;
    text-align: center !important;
    letter-spacing: -0.02em !important;
    background: linear-gradient(135deg, #ffffff 0%, #c7d2fe 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}
.tnt-gate-sub {
    margin: 0 0 18px !important;
    text-align: center !important;
    color: #cbd5e1 !important;
    font-size: 0.95rem !important;
    line-height: 1.55 !important;
}
.tnt-gate-hint {
    margin: 0 !important;
    text-align: center !important;
    color: #94a3b8 !important;
    font-size: 0.82rem !important;
    line-height: 1.55 !important;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    margin-top: 4px !important;
}
/* Eski tnt-gate-logo (kullanılırsa) */
.tnt-gate-logo {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin-bottom: 18px !important;
}
.tnt-gate-logo svg {
    filter: drop-shadow(0 8px 20px rgba(99, 102, 241, 0.5));
    border-radius: 14px;
}
/* ═══════════════════════════════════════════════════════════
   404 SAYFASI — fullscreen merkez konum garantisi (scoped CSS
   uygulanmazsa bile çalışsın)
   ═══════════════════════════════════════════════════════════ */
.nf-root {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px !important;
    background:
        radial-gradient(circle at 20% 20%, #312e81 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, #0e7490 0%, transparent 50%),
        linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%) !important;
    overflow: auto !important;
    z-index: 9999 !important;
    margin: 0 !important;
}
.nf-card {
    width: 100% !important;
    max-width: 520px !important;
    margin: auto !important;
    color: #e2e8f0 !important;
    text-align: center !important;
}
