/* =========================================================
   MODERN LIGHT UI (CLASS BOZMADAN) - FULL RESPONSIVE
   - card / row / btn / badge / table / modal
   - cx-* / kx-* / fx-* destekli
   ========================================================= */

/* -------------------------
   THEME TOKENS
-------------------------- */
:root{
  --bg:#f5f7fb;
  --surface:#ffffff;
  --text:#0f172a;
  --muted:#6b7280;

  --accent:#2563eb;
  --accent-ghost:#e8f0ff;
  --border:#e9edf5;

  --shadow:0 10px 30px rgba(15,23,42,.08);
  --shadow2:0 2px 10px rgba(15,23,42,.06);

  --radius:14px;

  --danger:#ef4444;
  --ok:#16a34a;
  --warning:#f59e0b;
}

/* -------------------------
   BASE RESET
-------------------------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
hr{border:none;border-top:1px solid var(--border);margin:14px 0}

/* -------------------------
   LAYOUT (varsa)
-------------------------- */
.container{max-width:none;margin:0 auto;padding:0}

.topbar{
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 18px;
  background:linear-gradient(90deg,#4e8ee8 0%, #3b82f6 55%, #2dd4bf 130%);
  border-bottom:1px solid rgba(255,255,255,.18);
  position:sticky;
  top:0;
  z-index:20;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  color:#fff;
  font-weight:800;
  letter-spacing:.2px;
}
.topbar .row{display:flex;gap:10px;align-items:center;flex-wrap:nowrap}

.layout{
  display:grid;
  grid-template-columns:280px 1fr;
  min-height:calc(100vh - 64px);
}
.sidebar{
  background:var(--surface);
  border-right:1px solid var(--border);
  padding:16px 12px;
  position:sticky;
  top:64px;
  height:calc(100vh - 64px);
  overflow:auto;
}
.main{padding:18px}
.layout > main {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: 10px;
    margin-right: 10px;
}
@media (max-width: 640px){
  .topbar .brand .brand-text{ 
    display:none !important; 
  }
}

.sb-wrap{display:flex;flex-direction:column;gap:14px}
.sb-brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;padding:8px 10px}
.sb-brand .logo{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background:#f1f5ff;
  color:var(--accent);
  border:1px solid var(--border);
}
.sb-profile{
  display:flex;align-items:center;gap:10px;
  padding:10px;
  border-radius:14px;
  background:linear-gradient(180deg,#f8fbff 0%, #f4f8ff 100%);
  border:1px solid var(--border);
}
.sb-avatar{
  width:40px;height:40px;border-radius:999px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,#2563eb 0%, #60a5fa 100%);
  color:#fff;
  font-weight:600;
}
.sb-user .name{font-weight:900}
.sb-user .role{font-size:12px;color:var(--muted);margin-top:2px}

.side-title{
  font-size:12px;
  color:#9aa3b2;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin:10px 10px 6px;
}
.side a{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:12px;
  color:#111827;
  margin:2px 6px;
  transition:background .15s ease, color .15s ease, transform .12s ease;
}
.side a:hover{background:#f3f6ff; transform:translateY(-1px)}
.side a.active{
  background:var(--accent-ghost);
  color:var(--accent);
  font-weight:600;
  border:1px solid rgba(37,99,235,.18);
}

/* -------------------------
   TYPO / HELPERS
-------------------------- */
.h1{font-size:20px;margin:0 0 6px;font-weight:600;letter-spacing:-.2px}
.h2{font-size:16px;margin:0 0 10px;font-weight:600;letter-spacing:-.15px}
small{color:var(--muted)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}

/* -------------------------
   CARD (senin php'lerdeki .card)
-------------------------- */
.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow2);
  padding:16px;
  margin-bottom:14px;
}
.card .h1, .card .h2{margin-top:0}

/* -------------------------
   GRID (ayarlar.php gibi)
-------------------------- */
.grid{display:grid;grid-template-columns:repeat(12, minmax(0,1fr));gap:14px}
.col-12{grid-column:span 12}
.col-6{grid-column:span 6}
.col-4{grid-column:span 4}
.col-3{grid-column:span 3}

/* -------------------------
   BUTTONS (senin .btn)
-------------------------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:12px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#fbfdff 0%, #f6f9ff 100%);
  color:var(--text);
  cursor:pointer;
  font-weight:600;
  line-height:1;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow2);
  background:#fff;
  border-color:#dfe7f5;
}
.btn:active{transform:translateY(0)}

.btn-primary{
  background:linear-gradient(135deg, rgba(37,99,235,.14) 0%, rgba(59,130,246,.08) 100%);
  border-color:rgba(37,99,235,.22);
  color:var(--accent);
}
.btn-primary:hover{
  background:linear-gradient(135deg, rgba(37,99,235,.18) 0%, rgba(59,130,246,.10) 100%);
}
.btn-danger{
  background:linear-gradient(135deg, rgba(239,68,68,.12) 0%, rgba(239,68,68,.06) 100%);
  border-color:rgba(239,68,68,.22);
  color:var(--danger);
}
.btn-danger:hover{
  background:linear-gradient(135deg, rgba(239,68,68,.16) 0%, rgba(239,68,68,.08) 100%);
}

/* -------------------------
   BADGE
-------------------------- */
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,#ffffff 0%, #f7faff 100%);
  font-weight:600;
  font-size:12px;
  box-shadow:var(--shadow2);
}

/* -------------------------
   FORMS (label > input/select)
-------------------------- */
label small{
  display:block;
  font-size:12px;
  color:var(--muted);
  font-weight:600;
  margin-bottom:6px;
}
input,select,textarea{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  color:var(--text);
  outline:none;
  transition:box-shadow .12s ease, border-color .12s ease;
}
input:focus,select:focus,textarea:focus{
  border-color:rgba(37,99,235,.35);
  box-shadow:0 0 0 4px rgba(37,99,235,.10);
}
textarea{min-height:90px}


/* -------------------------
   TABLE RESPONSIVE WRAPPER
-------------------------- */
.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-responsive > table{min-width:720px}
@media (max-width:760px){
  .table-responsive > table{min-width:640px}
}

/* -------------------------
   TABLE (Depolar.php gibi)
-------------------------- */
table{width:100%;border-collapse:separate;border-spacing:0 8px}
thead th{
  font-size:11px;
  color:#93a0b4;
  text-transform:uppercase;
  letter-spacing:.06em;
  text-align:left;
  padding:0 10px;
  white-space:nowrap;
}
tbody td{
  background:#fff;
  border-top:1px solid rgba(15,23,42,.08);
  border-bottom:1px solid rgba(15,23,42,.08);
  padding:10px;
  font-size:13px;
  vertical-align:middle;
}
tbody tr td:first-child{
  border-left:1px solid rgba(15,23,42,.08);
  border-top-left-radius:12px;
  border-bottom-left-radius:12px;
}
tbody tr td:last-child{
  border-right:1px solid rgba(15,23,42,.08);
  border-top-right-radius:12px;
  border-bottom-right-radius:12px;
}

/* td.row içindeki butonlar */
td.row{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
td.row .btn{white-space:nowrap}

/* -------------------------
   MODAL (senin .modal / .modal-icerik)
   JS class: .acik / .open / style display:block hepsini destekler
-------------------------- */
body.modal-acik{overflow:hidden}
.modal{
  position:fixed;inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(15,23,42,.55);
  z-index:999999;
  padding:16px;
  backdrop-filter: blur(6px);
}
.modal.acik,
.modal.open{display:flex}
.modal[style*="display: block"]{display:flex}

.modal-icerik{
  width:min(820px,100%);
  max-height:90vh;
  overflow:auto;
  background:#fff;
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:0 22px 70px rgba(0,0,0,.28);
  padding:14px;
  -webkit-overflow-scrolling:touch;
}
.modal-ust{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
  position:sticky;
  top:0;
  background:#fff;
  padding-bottom:10px;
  z-index:2;
}
.modal-kapat{
  width:40px;height:40px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  cursor:pointer;
  font-size:20px;
  display:grid;
  place-items:center;
}
.modal-kapat:hover{background:#f3f6ff}

/* =========================================================
   RESPONSIVE (GENEL)
========================================================= */
@media (max-width: 980px){
  .layout{grid-template-columns:1fr}
  .sidebar{
    position:relative;
    top:auto;
    height:auto;
    border-right:none;
    border-bottom:1px solid var(--border);
  }
  .main{padding:14px}
  .col-6,.col-4,.col-3{grid-column:span 12}
}

@media (max-width: 720px){
  .card{padding:12px}
  .h1{font-size:18px}
  .h2{font-size:15px}
}

@media (max-width: 560px){
  .card{padding:12px}
  .row{gap:8px}
  .btn{width:100%}                 /* üst bar butonları mobilde tam */
  td.row .btn{width:100%}          /* aksiyon butonları da tam */
  .badge{width:100%;justify-content:center}
  .modal{align-items:flex-end;padding:10px}
  .modal-icerik{
    width:100%;
    border-radius:16px 16px 0 0;
    max-height:92vh;
    padding:12px;
  }
}

/* =========================================================
   ✅ DEP0LAR TABLOSU MOBİLDE "KART" GÖRÜNÜM
   (HTML değiştirmeden)
   Depolar tablosu 5 kolon: Kod / Ad / Tür / Aktif / İşlem
========================================================= */
@media (max-width: 760px){
  table{border-spacing:0}
  thead{display:none}
  tbody, tr, td{display:block;width:100%}

  tbody tr{
    margin:0 0 12px 0;
    background:#fff;
    border:1px solid rgba(15,23,42,.10);
    border-radius:16px;
    box-shadow:var(--shadow2);
    overflow:hidden;
  }
  tbody td{
    border:0 !important;
    background:transparent !important;
    padding:10px 12px;
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:12px;
    font-size:13px;
  }
  tbody td + td{border-top:1px solid rgba(15,23,42,.08) !important}

  /* label */
  tbody td::before{
    font-weight:600;
    color:var(--muted);
    font-size:12px;
    min-width:110px;
    content:"";
  }
  tbody tr td:nth-child(1)::before{content:"KOD";}
  tbody tr td:nth-child(2)::before{content:"AD";}
  tbody tr td:nth-child(3)::before{content:"TÜR";}
  tbody tr td:nth-child(4)::before{content:"AKTİF";}
  tbody tr td:nth-child(5)::before{content:"İŞLEM";}

  /* aksiyonlar */
  td.row{justify-content:flex-start}
  td.row .btn{width:100%}
}

/* =========================================================
   CX / KX / FX (class bozmadan modernleştirme)
   - senin verdiğin isimlerle
========================================================= */

/* ---------- CX ---------- */
.cx-wrap{padding:16px; max-width:1500px; margin:0 auto}
.cx-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius:16px;
  box-shadow:var(--shadow2);
  padding:14px;
}
.cx-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.cx-title{font-size:18px;font-weight:600;margin:0;letter-spacing:-.2px}
.cx-sub{color:var(--muted);font-size:12px;margin-top:4px}
.cx-btn{
  border:1px solid rgba(15,23,42,.10);
  background:linear-gradient(180deg,#ffffff 0%, #f6f9ff 100%);
  padding:10px 12px;
  border-radius:12px;
  font-weight:600;
  cursor:pointer;
  display:inline-flex;
  gap:8px;
  align-items:center;
  text-decoration:none;
  transition:transform .12s ease, box-shadow .12s ease, background .15s ease;
}
.cx-btn:hover{transform:translateY(-1px); box-shadow:var(--shadow2); background:#fff}
.cx-btn.primary{background:linear-gradient(135deg,#3b82f6 0%, #2563eb 100%);color:#fff;border-color:rgba(37,99,235,.35)}
.cx-btn.danger{background:linear-gradient(135deg,#ef4444 0%, #fb7185 120%);color:#fff;border-color:rgba(239,68,68,.35)}
.cx-btn.small{padding:8px 10px;border-radius:10px;font-size:12px}
.cx-alert{margin-top:12px;padding:10px 12px;border-radius:12px;font-weight:900}
.cx-alert.ok{background:rgba(22,163,74,.08);color:#065f46;border:1px solid rgba(22,163,74,.20)}
.cx-alert.err{background:rgba(239,68,68,.08);color:#991b1b;border:1px solid rgba(239,68,68,.20)}
.cx-table-wrap{overflow:auto;margin-top:12px;-webkit-overflow-scrolling:touch}
.cx-table{width:100%;border-collapse:separate;border-spacing:0 8px;min-width:1200px}
.cx-table th{font-size:11px;color:var(--muted);text-align:left;padding:0 10px;white-space:nowrap}
.cx-table td{background:#fff;border-top:1px solid rgba(15,23,42,.08);border-bottom:1px solid rgba(15,23,42,.08);padding:10px;font-size:13px;vertical-align:middle}
.cx-table tr td:first-child{border-left:1px solid rgba(15,23,42,.08);border-top-left-radius:12px;border-bottom-left-radius:12px}
.cx-table tr td:last-child{border-right:1px solid rgba(15,23,42,.08);border-top-right-radius:12px;border-bottom-right-radius:12px}
.cx-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-variant-numeric:tabular-nums}
.cx-right{text-align:right}
.cx-actions{white-space:nowrap;text-align:right;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.cx-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid transparent}
.cx-badge.pos{background:rgba(22,163,74,.10);color:#065f46;border-color:rgba(22,163,74,.22)}
.cx-badge.neg{background:rgba(239,68,68,.10);color:#991b1b;border-color:rgba(239,68,68,.22)}
.cx-badge.z{background:rgba(107,114,128,.10);color:#374151;border-color:rgba(107,114,128,.18)}

.cx-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;padding:14px;z-index:999999;backdrop-filter:blur(6px)}
.cx-modal.open{display:flex}
.cx-modal-box{width:min(980px,100%);background:#fff;border-radius:16px;border:1px solid rgba(15,23,42,.10);box-shadow:0 22px 70px rgba(0,0,0,.28);padding:14px;max-height:calc(100vh - 28px);overflow:auto;-webkit-overflow-scrolling:touch}
.cx-modal-top{display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;background:#fff;padding-bottom:10px;z-index:2}
.cx-x{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px}
.cx-form{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
@media(max-width:900px){.cx-form{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.cx-form{grid-template-columns:1fr}}
.cx-field label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px}
.cx-inp{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);outline:none}
.cx-inp:focus{border-color:rgba(37,99,235,.35);box-shadow:0 0 0 4px rgba(37,99,235,.10)}
.cx-footer{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:12px}
.cx-note{font-size:12px;color:var(--muted)}
.cx-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
@media(max-width:900px){.cx-grid2{grid-template-columns:1fr}}
.cx-mini{border:1px solid var(--border);border-radius:16px;padding:12px;background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%)}
.cx-mini h4{margin:0 0 8px 0;font-size:13px;font-weight:900}
.cx-mini .rowx{display:flex;justify-content:space-between;gap:10px;font-size:12px;margin:6px 0;color:#374151;flex-wrap:wrap}
.cx-mini table{width:100%;border-collapse:separate;border-spacing:0 8px}
.cx-mini td{font-size:12px;padding:8px;border:1px solid rgba(15,23,42,.08);border-radius:12px;background:#fff}

/* CX mobile: tablo kart */
@media(max-width:640px){
  .cx-table{min-width:0;width:100%;border-spacing:0}
  .cx-table thead{display:none}
  .cx-table tbody,.cx-table tr,.cx-table td{display:block;width:100%}
  .cx-table tr{margin:0 0 12px;background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:16px;box-shadow:var(--shadow2);overflow:hidden}
  .cx-table td{border:0;background:transparent;padding:10px 12px;display:flex;justify-content:space-between;gap:12px}
  .cx-table td + td{border-top:1px solid rgba(15,23,42,.08)}
  .cx-table td::before{content:"";font-weight:600;color:var(--muted);font-size:12px;min-width:110px}
  /* 9 kolon varsayımı (senin kullandıkların) */
  .cx-table tr td:nth-child(1)::before{content:"ID"}
  .cx-table tr td:nth-child(2)::before{content:"KOD"}
  .cx-table tr td:nth-child(3)::before{content:"AD"}
  .cx-table tr td:nth-child(4)::before{content:"PB"}
  .cx-table tr td:nth-child(5)::before{content:"GİRİŞ"}
  .cx-table tr td:nth-child(6)::before{content:"ÇIKIŞ"}
  .cx-table tr td:nth-child(7)::before{content:"BAKİYE"}
  .cx-table tr td:nth-child(8)::before{content:"AKTİF"}
  .cx-table tr td:nth-child(9)::before{content:"İŞLEM"}
  .cx-actions{width:100%;justify-content:flex-start}
  .cx-actions .cx-btn{flex:1;justify-content:center}
}

/* ---------- KX ---------- */
.kx-wrap{padding:16px; max-width:1500px; margin:0 auto}
.kx-card{background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:16px;box-shadow:var(--shadow2);padding:14px;margin-bottom:12px}
.kx-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.kx-title{font-size:18px;font-weight:600;margin:0;letter-spacing:-.2px}
.kx-sub{color:var(--muted);font-size:12px;margin-top:4px}
.kx-btn{border:1px solid rgba(15,23,42,.10);background:linear-gradient(180deg,#ffffff 0%, #f6f9ff 100%);padding:10px 12px;border-radius:12px;font-weight:600;cursor:pointer;display:inline-flex;gap:8px;align-items:center;text-decoration:none;transition:transform .12s ease, box-shadow .12s ease}
.kx-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow2)}
.kx-btn.primary{background:linear-gradient(135deg,#3b82f6 0%, #2563eb 100%);color:#fff;border-color:rgba(37,99,235,.35)}
.kx-btn.danger{background:linear-gradient(135deg,#ef4444 0%, #fb7185 120%);color:#fff;border-color:rgba(239,68,68,.35)}
.kx-btn.small{padding:8px 10px;border-radius:10px;font-size:12px}
.kx-alert{margin-top:12px;padding:10px 12px;border-radius:12px;font-weight:900}
.kx-alert.ok{background:rgba(22,163,74,.08);color:#065f46;border:1px solid rgba(22,163,74,.20)}
.kx-alert.err{background:rgba(239,68,68,.08);color:#991b1b;border:1px solid rgba(239,68,68,.20)}
.kx-table-wrap{overflow:auto;margin-top:12px;-webkit-overflow-scrolling:touch}
.kx-table{width:100%;border-collapse:separate;border-spacing:0 8px;min-width:1100px}
.kx-table th{font-size:11px;color:var(--muted);text-align:left;padding:0 10px;white-space:nowrap}
.kx-table td{background:#fff;border-top:1px solid rgba(15,23,42,.08);border-bottom:1px solid rgba(15,23,42,.08);padding:10px;font-size:13px;vertical-align:middle}
.kx-table tr td:first-child{border-left:1px solid rgba(15,23,42,.08);border-top-left-radius:12px;border-bottom-left-radius:12px}
.kx-table tr td:last-child{border-right:1px solid rgba(15,23,42,.08);border-top-right-radius:12px;border-bottom-right-radius:12px}
.kx-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-variant-numeric:tabular-nums}
.kx-right{text-align:right}
.kx-actions{white-space:nowrap;text-align:right;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}
.kx-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid transparent}
.kx-badge.pos{background:rgba(22,163,74,.10);color:#065f46;border-color:rgba(22,163,74,.22)}
.kx-badge.neg{background:rgba(239,68,68,.10);color:#991b1b;border-color:rgba(239,68,68,.22)}
.kx-badge.z{background:rgba(107,114,128,.10);color:#374151;border-color:rgba(107,114,128,.18)}
.kx-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}
@media(max-width:900px){.kx-stats{grid-template-columns:1fr}}
.kx-stat{border:1px solid var(--border);border-radius:16px;padding:12px;background:linear-gradient(180deg,#ffffff 0%, #f8fbff 100%)}
.kx-stat .l{font-size:11px;color:var(--muted);font-weight:900}
.kx-stat .v{font-size:18px;font-weight:600;margin-top:6px}
.kx-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.kx-tab{padding:10px 12px;border-radius:12px;border:1px solid rgba(15,23,42,.10);background:#fff;font-weight:600;text-decoration:none;color:#111;transition:transform .12s ease}
.kx-tab:hover{transform:translateY(-1px)}
.kx-tab.active{background:#111827;color:#fff;border-color:#111827}
.kx-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;padding:14px;z-index:999999;backdrop-filter:blur(6px)}
.kx-modal.open{display:flex}
.kx-modal-box{width:min(900px,100%);background:#fff;border-radius:16px;border:1px solid rgba(15,23,42,.10);box-shadow:0 22px 70px rgba(0,0,0,.28);padding:14px;max-height:calc(100vh - 28px);overflow:auto;-webkit-overflow-scrolling:touch}
.kx-modal-top{display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;background:#fff;padding-bottom:10px;z-index:2}
.kx-x{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px}
.kx-form{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
@media(max-width:900px){.kx-form{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.kx-form{grid-template-columns:1fr}}
.kx-field label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px}
.kx-inp{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);outline:none}
.kx-inp:focus{border-color:rgba(37,99,235,.35);box-shadow:0 0 0 4px rgba(37,99,235,.10)}
.kx-footer{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:12px}
.kx-note{font-size:12px;color:var(--muted)}
.kx-sep{grid-column:span 4;height:1px;background:var(--border);margin:6px 0}
.kx-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;font-weight:600;background:#fff}
.kx-muted{color:var(--muted);font-size:12px}
.kx-hide{display:none!important}

@media(max-width:560px){
  .kx-wrap{padding:12px}
  .kx-head{flex-direction:column;align-items:flex-start}
  .kx-btn{width:100%;justify-content:center}
  .kx-actions .kx-btn{width:auto}
}

/* ---------- FX ---------- */
.fx-wrap{padding:16px; max-width:1400px; margin:0 auto}
.fx-card{background:#fff;border:1px solid rgba(15,23,42,.10);border-radius:16px;box-shadow:var(--shadow2);padding:14px}
.fx-head{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.fx-title{font-size:18px;font-weight:600;margin:0;letter-spacing:-.2px}
.fx-sub{color:var(--muted);font-size:12px;margin-top:4px}
.fx-btn{border:1px solid rgba(15,23,42,.10);background:linear-gradient(180deg,#ffffff 0%, #f6f9ff 100%);padding:10px 12px;border-radius:12px;font-weight:600;cursor:pointer;display:inline-flex;gap:8px;align-items:center;text-decoration:none;transition:transform .12s ease, box-shadow .12s ease}
.fx-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow2)}
.fx-btn.primary{background:linear-gradient(135deg,#3b82f6 0%, #2563eb 100%);color:#fff;border-color:rgba(37,99,235,.35)}
.fx-btn.danger{background:linear-gradient(135deg,#ef4444 0%, #fb7185 120%);color:#fff;border-color:rgba(239,68,68,.35)}
.fx-btn.small{padding:8px 10px;border-radius:10px;font-size:12px}
.fx-alert{margin-top:12px;padding:10px 12px;border-radius:12px;font-weight:900}
.fx-alert.ok{background:rgba(22,163,74,.08);color:#065f46;border:1px solid rgba(22,163,74,.20)}
.fx-alert.err{background:rgba(239,68,68,.08);color:#991b1b;border:1px solid rgba(239,68,68,.20)}
.fx-table-wrap{overflow:auto;margin-top:12px;-webkit-overflow-scrolling:touch}
.fx-table{width:100%;border-collapse:separate;border-spacing:0 8px;min-width:1200px}
.fx-table th{font-size:11px;color:var(--muted);text-align:left;padding:0 10px;white-space:nowrap}
.fx-table td{background:#fff;border-top:1px solid rgba(15,23,42,.08);border-bottom:1px solid rgba(15,23,42,.08);padding:10px;font-size:13px;vertical-align:middle}
.fx-table tr td:first-child{border-left:1px solid rgba(15,23,42,.08);border-top-left-radius:12px;border-bottom-left-radius:12px}
.fx-table tr td:last-child{border-right:1px solid rgba(15,23,42,.08);border-top-right-radius:12px;border-bottom-right-radius:12px}
.fx-badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:11px;font-weight:900}
.fx-badge.in{background:rgba(22,163,74,.10);color:#065f46;border:1px solid rgba(22,163,74,.22)}
.fx-badge.out{background:rgba(239,68,68,.10);color:#991b1b;border:1px solid rgba(239,68,68,.22)}
.fx-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-variant-numeric:tabular-nums}
.fx-right{text-align:right}
.fx-actions-td{white-space:nowrap;text-align:right;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}

.fx-modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;padding:14px;z-index:999999;backdrop-filter:blur(6px)}
.fx-modal.open{display:flex}
.fx-modal-box{width:min(920px,100%);max-height:calc(100vh - 28px);overflow:auto;background:#fff;border-radius:16px;border:1px solid rgba(15,23,42,.10);box-shadow:0 22px 70px rgba(0,0,0,.28);padding:14px}
.fx-modal-top{display:flex;align-items:center;justify-content:space-between;gap:10px;position:sticky;top:0;background:#fff;padding-bottom:10px;z-index:2}
.fx-x{width:40px;height:40px;border-radius:12px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:18px;text-decoration:none;display:flex;align-items:center;justify-content:center}
.fx-form{margin-top:12px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
@media(max-width:900px){.fx-form{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.fx-form{grid-template-columns:1fr}}
.fx-field label{display:block;font-size:12px;color:var(--muted);font-weight:600;margin-bottom:6px}
.fx-inp{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);outline:none}
.fx-inp:focus{border-color:rgba(37,99,235,.35);box-shadow:0 0 0 4px rgba(37,99,235,.10)}
.fx-footer{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:12px}
.fx-note{font-size:12px;color:var(--muted)}


:root{
  --db-br: rgba(15,23,42,.10);
  --db-tx: #0f172a;
  --db-mu: rgba(15,23,42,.62);
  --db-sh: 0 18px 60px rgba(15,23,42,.08);
  --db-r: 18px;

  --c1: rgba(59,130,246,.85);
  --c2: rgba(34,197,94,.80);
  --c3: rgba(245,158,11,.85);
  --c4: rgba(168,85,247,.80);
  --c5: rgba(239,68,68,.80);
}

/* --- TOP LAYOUT --- */
.db-wrap{display:flex;flex-direction:column;gap:14px}
.db-grid{
  display:grid;
  grid-template-columns:repeat(12, minmax(0,1fr));
  gap:14px;
  align-items:stretch;
}
.db-span-12{grid-column:span 12}
.db-span-6{grid-column:span 6}
.db-span-4{grid-column:span 4}
.db-span-3{grid-column:span 3}

@media (max-width: 1100px){
  .db-span-3{grid-column:span 6}
}
@media (max-width: 700px){
  .db-span-6,.db-span-4,.db-span-3{grid-column:span 12}
}

/* --- CARDS --- */
.db-card{
  border:1px solid var(--db-br);
  border-radius:var(--db-r);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.74));
  box-shadow:var(--db-sh);
  overflow:hidden;
  height:100%;
  display:flex;
  flex-direction:column;
}
.db-card .hd{
  padding:14px 14px 10px 14px;
  display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;
}
.db-card .body{
  padding:0 14px 14px 14px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.db-title{font-size:16px;font-weight:700;color:var(--db-tx);margin:0}
.db-sub{font-size:12px;color:var(--db-mu);margin-top:2px}

.db-ttl{display:flex;align-items:center;gap:10px}
.db-ico{
  width:40px;height:40px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.03);
  font-size:18px;
}

.small{font-size:12px}
.muted{color:var(--db-mu)}

/* --- KPI --- */
.kpi{
  position:relative;
  border:1px solid var(--db-br);
  border-radius:var(--db-r);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.74));
  box-shadow:var(--db-sh);
  padding:14px;
  overflow:hidden;
  height:100%;
}
.kpi .bar{position:absolute;left:0;top:0;bottom:0;width:6px}
.kpi .t{font-size:12px;color:var(--db-mu);font-weight:700;letter-spacing:.2px}
.kpi .v{font-size:32px;font-weight:700;line-height:1.1;margin-top:6px;color:var(--db-tx)}
.kpi .s{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.kpi .chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(15,23,42,.03);
  color: var(--db-tx);
  font-size:12px;
  font-weight:700;
}
.kpi .ico{
  width:44px;height:44px;border-radius:16px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(15,23,42,.10);
  background: rgba(255,255,255,.75);
  font-size:20px;
}
.kpi.c1 .bar{background:var(--c1)}
.kpi.c2 .bar{background:var(--c2)}
.kpi.c3 .bar{background:var(--c3)}
.kpi.c4 .bar{background:var(--c4)}

/* --- NOTIF --- */
.notif-wrap{position:relative}
.notif-btn{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.72);
  color:var(--db-tx);
  padding:10px 12px;border-radius:14px;cursor:pointer;
  box-shadow:0 10px 30px rgba(15,23,42,.10);
  backdrop-filter: blur(10px);
}
.notif-dot{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 7px;
  border-radius:999px;font-size:12px;font-weight:700;
  background:rgba(239,68,68,.10);
  border:1px solid rgba(239,68,68,.22);
  color:#dc2626;
}
.notif-dd{
  position:absolute;right:0;top:46px;z-index:9999;
  width:min(380px, 92vw);
  background:rgba(255,255,255,.94);
  border:1px solid rgba(15,23,42,.12);
  border-radius:18px;
  box-shadow:0 18px 60px rgba(15,23,42,.18);
  display:none; overflow:hidden;
  backdrop-filter: blur(14px);
}
.notif-dd.acik{display:block}
.notif-dd .hd{
  padding:12px 14px;
  border-bottom:1px solid rgba(15,23,42,.08);
  display:flex;justify-content:space-between;align-items:center;
}
.notif-dd .it{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  padding:12px 14px;
  border-bottom:1px solid rgba(15,23,42,.06);
  text-decoration:none;color:var(--db-tx);
}
.notif-dd .it:hover{background:rgba(59,130,246,.08)}
.pill{
  padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;
  border:1px solid rgba(15,23,42,.10);
  background:rgba(15,23,42,.03);
}
.pill.warn{background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.22);color:#b45309}
.pill.danger{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.22);color:#b91c1c}
.pill.ok{background:rgba(34,197,94,.12);border-color:rgba(34,197,94,.22);color:#166534}

/* --- LISTS --- */
.list-clean{margin:0;padding:0;list-style:none}
.list-clean li{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  padding:10px 0;border-bottom:1px dashed rgba(15,23,42,.10);
}
.list-clean li:last-child{border-bottom:0}
.list-clean .nm{font-weight:700;color:var(--db-tx);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70%}
.list-clean .vl{font-weight:700;color:var(--db-tx);white-space:nowrap}

/* --- CHART --- */
.mini-chart{width:100%;height:auto;display:block}
.mini-chart .axis{stroke: rgba(15,23,42,.12); stroke-width:1}
.mini-chart .lbl{fill: rgba(15,23,42,.55); font-size:11px; font-weight:600}
.mini-chart .bar{fill: rgba(59,130,246,.60)}
.mini-chart .bar2{fill: rgba(34,197,94,.55)}
.mini-chart .bar3{fill: rgba(239,68,68,.45)}
.legend{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:8px}
.legend .dot{width:10px;height:10px;border-radius:99px;display:inline-block}
.legend .item{display:inline-flex;gap:6px;align-items:center;color:var(--db-mu);font-size:12px;font-weight:600}

.select-mini{
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.80);
  padding:8px 10px;border-radius:12px;
}

/* ROTA list hizalama fix (mobil) */
.rota-box{ padding:10px; }

.rota-item{
  display:grid !important;
  grid-template-columns: 22px 1fr;
  align-items:center;
  gap:12px;
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid transparent;
  cursor:pointer;
}

.rota-item input[type="checkbox"]{
  width:18px;
  height:18px;
  margin:0;
  justify-self:start;
}

.rota-item span{
  display:block;
  text-align:left;
  line-height:1.2;
  font-weight:700;
  color:var(--text);
}

.rota-item:hover{
  background:rgba(15,23,42,.03);
  border-color:rgba(15,23,42,.06);
}

/* küçük ekranlarda daha da rahat */
@media (max-width: 520px){
  .rota-item{
    padding:12px 12px;
    gap:10px;
  }
  .rota-item span{ font-size:14px; }
}

/* Search-select: seçilen değer (trigger) rozet gibi görünsün */
.ss-trigger.is-selected{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;

  padding:6px 12px;
  width:auto;              /* rozet gibi dursun */
  max-width:100%;
  border-radius:999px;

  /* badge badge-ok görünümü */
  background: rgba(34,197,94,.12);
  border: 1px solid rgba(34,197,94,.28);
  color: #16a34a;
  font-weight:600;

  box-shadow:none;
}

/* Trigger üzerindeki ok ikonu rozet modunda kalsın */
.ss-trigger.is-selected:after{
  margin-left:8px;
  border-right-color: rgba(22,163,74,.75);
  border-bottom-color: rgba(22,163,74,.75);
}

/* Seçilen yazı taşarsa */
.ss-trigger.is-selected{
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
