/* Brosis CRM — paylaşılan tasarım tokenları */
:root{
  /* Marka */
  --brand-primary:#1e3a8a;
  --brand-primary-700:#1e40af;
  --brand-primary-50:#eff2fb;
  --brand-dark:#1e293b;
  --brand-secondary:#f59e0b;
  --brand-secondary-50:#fef6e7;

  /* Semantik */
  --success:#10b981;
  --success-50:#ecfdf5;
  --warning:#f59e0b;
  --warning-50:#fef6e7;
  --danger:#ef4444;
  --danger-50:#fef2f2;
  --info:#3b82f6;
  --info-50:#eff6ff;
  --purple:#8b5cf6;
  --purple-50:#f5f3ff;
  --emerald:#059669;
  --emerald-50:#d1fae5;

  /* Nötr */
  --ink-900:#0b1220;
  --ink-700:#1e293b;
  --ink-500:#475569;
  --ink-400:#64748b;
  --ink-300:#94a3b8;
  --ink-200:#cbd5e1;
  --ink-100:#e2e8f0;
  --ink-50:#f1f5f9;
  --ink-25:#f8fafc;
  --paper:#ffffff;

  /* Radii */
  --r-xs:4px;
  --r-sm:6px;
  --r-md:8px;
  --r-lg:12px;
  --r-xl:16px;

  /* Shadow */
  --shadow-1:0 1px 2px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.04);
  --shadow-2:0 4px 12px rgba(15,23,42,.06), 0 1px 3px rgba(15,23,42,.04);
  --shadow-3:0 16px 32px rgba(15,23,42,.10), 0 4px 12px rgba(15,23,42,.06);
}

*{box-sizing:border-box}
html,body{margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink-900);background:var(--ink-50);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
.mono{font-family:'JetBrains Mono',ui-monospace,Menlo,monospace;font-feature-settings:'tnum' 1}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:9px 14px;border-radius:var(--r-md);font-weight:500;font-size:14px;
  border:1px solid transparent;cursor:pointer;line-height:1;min-height:36px;
  transition:background .12s, border-color .12s, color .12s;
  font-family:inherit;
}
.btn .ic{width:16px;height:16px}
.btn-primary{background:var(--brand-primary);color:#fff}
.btn-primary:hover{background:#172f6f}
.btn-secondary{background:#fff;color:var(--ink-700);border-color:var(--ink-200)}
.btn-secondary:hover{background:var(--ink-25)}
.btn-ghost{background:transparent;color:var(--ink-500)}
.btn-ghost:hover{background:var(--ink-50);color:var(--ink-900)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#dc2626}
.btn-gold{background:var(--brand-secondary);color:#1c1917}
.btn-gold:hover{background:#d97706}
.btn-sm{padding:6px 10px;font-size:13px;min-height:30px}
.btn-lg{padding:12px 18px;font-size:15px;min-height:44px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* === Badges === */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 8px;border-radius:999px;
  font-size:12px;font-weight:500;line-height:1.4;white-space:nowrap;
  border:1px solid transparent;
}
.badge .pip{width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.badge-bot{background:var(--success-50);color:#047857;border-color:#a7f3d0}
.badge-manual{background:var(--danger-50);color:#b91c1c;border-color:#fecaca}
.badge-status-new{background:var(--ink-100);color:var(--ink-700);border-color:var(--ink-200)}
.badge-status-dekont{background:var(--warning-50);color:#92400e;border-color:#fde68a}
.badge-status-myk{background:var(--info-50);color:#1e40af;border-color:#bfdbfe}
.badge-status-pass{background:var(--success-50);color:#047857;border-color:#a7f3d0}
.badge-status-fail{background:var(--danger-50);color:#b91c1c;border-color:#fecaca}
.badge-status-belge{background:var(--purple-50);color:#6d28d9;border-color:#ddd6fe}
.badge-status-done{background:var(--emerald-50);color:#065f46;border-color:#6ee7b7}
.badge-status-hold{background:#fff7ed;color:#9a3412;border-color:#fed7aa}

/* === Card === */
.card{background:var(--paper);border:1px solid var(--ink-100);border-radius:var(--r-lg);box-shadow:var(--shadow-1)}
.card-pad{padding:18px}
.card-hd{padding:14px 18px;border-bottom:1px solid var(--ink-100);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.card-hd h3{margin:0;font-size:14px;font-weight:600;color:var(--ink-900)}
.card-hd .hd-meta{margin-left:auto;color:var(--ink-400);font-size:12px}

/* === Input === */
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;font-weight:500;color:var(--ink-500)}
.input,.select,.textarea{
  width:100%;font:inherit;font-size:14px;color:var(--ink-900);
  background:#fff;border:1px solid var(--ink-200);border-radius:var(--r-md);
  padding:9px 12px;min-height:38px;outline:none;
  transition:border-color .12s, box-shadow .12s;
}
.input:focus,.select:focus,.textarea:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px rgba(30,58,138,.12)}
.select-sm{width:auto;min-height:30px;padding:4px 26px 4px 8px;font-size:13px;cursor:pointer}
.textarea{min-height:80px;resize:vertical;line-height:1.5}
.input::placeholder,.textarea::placeholder{color:var(--ink-300)}
.input-icon{position:relative}
.input-icon .input{padding-left:36px}
.input-icon svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--ink-400);width:16px;height:16px}

/* Toggle */
.toggle{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none}
.toggle input{position:absolute;opacity:0;pointer-events:none}
.toggle .track{width:36px;height:20px;border-radius:999px;background:var(--ink-200);position:relative;transition:background .15s}
.toggle .track::after{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.2);transition:left .15s}
.toggle input:checked + .track{background:var(--success)}
.toggle input:checked + .track::after{left:18px}
.toggle.danger input:checked + .track{background:var(--danger)}

/* Table */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}

/* Aday detay → Konuşma sekmesi sohbet panosu.
   Fixed-height + internal-scroll yerine STICKY-INPUT deseni:
   - chat-body doğal akışla uzar (kendi içinde kaymaz)
   - chat-input position:sticky;bottom:0 ile viewport dibine yapışır
   Bu sayede top-stack yüksekliği değişse de input her zaman görünür,
   matematik gerekmez, her cihaz boyutunda çalışır. */
/* Aday detay üst kısmı (banner + tabs) sticky: sayfa kaydırılsa da
   kim ile konuşulduğu + sekme değiştir bağlantısı her zaman üstte.

   ÖNEMLİ: global `.content{overflow:hidden}` sticky'yi kırar (scroll
   bağlamı .content olur). Bunu içeren sayfada overflow override edilir
   (`:has` ile, ek template class'ına gerek yok). */
.content:has(> .cd-stickyhead),
.content:has(.cd-stickyhead){overflow:visible !important}
.cd-stickyhead{position:sticky;top:0;z-index:20;background:#f8fafc;padding-top:12px;margin-top:-12px}
.cd-stickyhead .tabs{background:#fff;margin-top:0;border-radius:0 0 8px 8px;box-shadow:0 6px 12px -8px rgba(15,23,42,.08)}

.chat-pane-detay{height:auto !important;min-height:0 !important;background:transparent !important;overflow:visible !important}
.chat-pane-detay .chat-body{flex:none !important;overflow:visible !important;max-height:none !important}
.chat-pane-detay .chat-input{
  position:sticky;bottom:0;z-index:5;background:#fff;
  border-top:1px solid var(--ink-100);
  box-shadow:0 -8px 16px -10px rgba(15,23,42,.08);
  padding-bottom:calc(12px + env(safe-area-inset-bottom, 0px));
}
@media (max-width:768px){
  /* Mobilde .mtab navi alttan 60+safe-area kadar yer kapatıyor;
     sticky input bunun ÜSTÜNE oturmalı. */
  .chat-pane-detay .chat-input{
    bottom:calc(60px + env(safe-area-inset-bottom, 0px));
    padding-bottom:12px;
  }
}
.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.tbl thead th{
  text-align:left;font-weight:500;color:var(--ink-500);
  padding:10px 14px;background:var(--ink-25);
  border-bottom:1px solid var(--ink-100);font-size:12px;
  text-transform:uppercase;letter-spacing:.04em;
}
.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--ink-100);vertical-align:middle}
.tbl tbody tr:hover{background:var(--ink-25)}
.tbl tbody tr:last-child td{border-bottom:0}

/* Avatar */
.avatar{
  width:32px;height:32px;border-radius:50%;
  display:inline-grid;place-items:center;color:#fff;font-weight:600;font-size:12px;
  background:linear-gradient(135deg,#3b5bdb,#1e3a8a);
  flex:none;
}
.avatar.lg{width:48px;height:48px;font-size:16px}
.avatar.xl{width:64px;height:64px;font-size:20px}
.avatar.sm{width:24px;height:24px;font-size:10px}
.avatar.g1{background:linear-gradient(135deg,#fb923c,#ea580c)}
.avatar.g2{background:linear-gradient(135deg,#10b981,#047857)}
.avatar.g3{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.avatar.g4{background:linear-gradient(135deg,#06b6d4,#0e7490)}
.avatar.g5{background:linear-gradient(135deg,#f43f5e,#be123c)}

/* Banner / Alert */
.banner{display:flex;gap:12px;padding:12px 14px;border-radius:var(--r-md);border:1px solid transparent;font-size:13px;align-items:flex-start}
.banner svg{width:18px;height:18px;flex:none;margin-top:1px}
.banner .b-body{flex:1}
.banner-warn{background:var(--warning-50);color:#92400e;border-color:#fde68a}
.banner-danger{background:var(--danger-50);color:#b91c1c;border-color:#fecaca}
.banner-success{background:var(--success-50);color:#065f46;border-color:#a7f3d0}
.banner-info{background:var(--info-50);color:#1e40af;border-color:#bfdbfe}

/* KPI tile */
.kpi{padding:18px;border-radius:var(--r-lg);background:#fff;border:1px solid var(--ink-100);box-shadow:var(--shadow-1)}
.kpi .k-lbl{font-size:12px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.kpi .k-val{font-family:'JetBrains Mono';font-size:30px;font-weight:600;color:var(--ink-900);margin-top:6px;letter-spacing:-0.02em}
.kpi .k-delta{display:inline-flex;gap:4px;align-items:center;margin-top:8px;font-size:12px;font-weight:500}
.kpi .k-delta.up{color:#047857}
.kpi .k-delta.dn{color:#b91c1c}
.kpi .k-delta.flat{color:var(--ink-400)}

/* Sparkline area */
.spark{display:block;width:100%;height:28px}

/* Chat bubbles */
/* ============================================
   WhatsApp-tarzı sohbet teması — Sohbetler + Aday detay Konuşma
   Her iki ekran da aynı .chat-body / .bubble class'larını kullanıyor.
   ============================================ */

/* Gün ayırıcı — WhatsApp'ın merkezi pill etiketi */
.chat-day{
  align-self:center;
  background:rgba(225,245,254,.92);
  color:#54656f;font-size:12px;font-weight:500;
  padding:5px 12px;border-radius:8px;
  box-shadow:0 1px 0.5px rgba(15,23,42,.13);
  margin:14px auto 8px;
}
.chat-day::before,.chat-day::after{content:none}

/* Bubble — WhatsApp şekli + kuyruk */
.bubble{
  max-width:75%;padding:6px 8px 8px 9px;border-radius:8px;
  font-size:14.2px;line-height:1.4;position:relative;
  box-shadow:0 1px 1px rgba(15,23,42,.08);
  word-wrap:break-word;
}
.bubble .msg{white-space:pre-wrap;word-break:break-word;display:inline}
.bubble .time{
  float:right;font-size:11px;color:rgba(0,0,0,.45);
  font-family:inherit;margin:5px 0 -3px 10px;white-space:nowrap;
  font-weight:400;
}
.bubble .who{
  font-size:10.5px;font-weight:600;text-transform:none;
  letter-spacing:0;margin-bottom:2px;
  color:#06cf9c;  /* WhatsApp marka tonu — gönderen rengi */
}
.bubble.manual .who{color:#1e3a8a}

/* Inbound (aday → biz) — beyaz, sol-alt kuyruk */
.bubble.in{
  background:#fff;align-self:flex-start;
  margin-left:8px;border-top-left-radius:0;
}
.bubble.in::before{
  content:"";position:absolute;left:-8px;top:0;
  width:8px;height:13px;background:#fff;
  clip-path:polygon(100% 0,100% 100%,0 0);
}

/* Outbound (biz → aday) — WhatsApp yeşili, sağ-alt kuyruk.
   Bot ve manuel aynı renk, fark üstteki "Bot · Otomatik" / "Manuel"
   etiketi ile (WhatsApp birleşik gönderen rengi). */
.bubble.bot,.bubble.manual{
  background:#d9fdd3;color:var(--ink-900);align-self:flex-end;
  margin-right:8px;border-top-right-radius:0;
}
.bubble.bot::before,.bubble.manual::before{
  content:"";position:absolute;right:-8px;top:0;
  width:8px;height:13px;background:#d9fdd3;
  clip-path:polygon(0 0,100% 0,0 100%);
}
.bubble.manual .time{color:rgba(0,0,0,.55)}

/* Sistem mesajları — merkez, italik, hafif (mevcut) */
.bubble.system{
  background:rgba(225,245,254,.85);color:#54656f;font-style:italic;
  align-self:center;font-size:12.5px;text-align:center;max-width:85%;
  box-shadow:0 1px 0.5px rgba(15,23,42,.10);
  border-radius:8px;padding:5px 10px;
}
.bubble.system::before{content:none}

/* Bubble içi belge linki (PDF vb. medya) */
.bubble .msg-doc{
  display:flex;align-items:center;gap:8px;
  background:rgba(0,0,0,.06);border-radius:8px;
  padding:8px 10px;margin:-1px -3px 5px;
  color:inherit;text-decoration:none;font-weight:500;font-size:13px;
}
.bubble .msg-doc:hover{background:rgba(0,0,0,.10)}
.bubble .msg-doc svg{width:22px;height:22px;flex:none;opacity:.7}

/* Misc */
.hr{height:1px;background:var(--ink-100);border:0;margin:0}
.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:var(--r-sm);background:var(--ink-50);font-size:11px;color:var(--ink-500);border:1px solid var(--ink-100);text-transform:uppercase;letter-spacing:.04em;font-weight:500}
.kbd{font-family:'JetBrains Mono';font-size:11px;padding:1px 5px;background:#fff;border:1px solid var(--ink-200);border-bottom-width:2px;border-radius:4px;color:var(--ink-500)}
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px;color:var(--ink-400)}
.empty .ic{width:48px;height:48px;border-radius:50%;background:var(--ink-50);display:grid;place-items:center;color:var(--ink-300);margin-bottom:12px}
.empty h4{margin:0 0 6px;color:var(--ink-700);font-size:14px;font-weight:600}
.empty p{margin:0;font-size:13px;max-width:280px}

/* Helpers */
.flex{display:flex}
.col{display:flex;flex-direction:column}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}
.items-center{align-items:center}
.justify-between{justify-content:space-between}
.w-full{width:100%}
.text-muted{color:var(--ink-400)}
.text-danger{color:var(--danger)}
.text-success{color:#047857}
.text-warn{color:#92400e}
.text-xs{font-size:12px}
.text-sm{font-size:13px}
.text-lg{font-size:16px}
.fw-500{font-weight:500}.fw-600{font-weight:600}

/* ============================================================ */
/* === DARK MODE (tweaks panel toggle ile aktif olur) ========= */
/* ============================================================ */
:root[data-theme="dark"]{
  --paper:#0f172a;
  --ink-25:#1e293b;
  --ink-50:#1e293b;
  --ink-100:#334155;
  --ink-200:#475569;
  --ink-300:#64748b;
  --ink-400:#94a3b8;
  --ink-500:#cbd5e1;
  --ink-700:#e2e8f0;
  --ink-900:#f8fafc;
  --shadow-1:0 1px 2px rgba(0,0,0,.4), 0 1px 3px rgba(0,0,0,.3);
  --shadow-2:0 4px 12px rgba(0,0,0,.5), 0 1px 3px rgba(0,0,0,.35);
  --shadow-3:0 16px 32px rgba(0,0,0,.6), 0 4px 12px rgba(0,0,0,.4);
}
:root[data-theme="dark"] body{background:#020617}
:root[data-theme="dark"] .card{background:#0f172a}
:root[data-theme="dark"] .kpi{background:#0f172a}
:root[data-theme="dark"] .demo-card{background:#0f172a}
:root[data-theme="dark"] .tnav{background:#0f172a}
:root[data-theme="dark"] .tnav .tn-search input{background:#1e293b;color:var(--ink-700)}
:root[data-theme="dark"] .top{background:#0f172a}
:root[data-theme="dark"] .top .top-search input{background:#1e293b}
:root[data-theme="dark"] .frame{background:#0f172a;border-color:#1e293b}
:root[data-theme="dark"] .app{background:#020617}
:root[data-theme="dark"] .app.tn{background:#020617}
:root[data-theme="dark"] .main{background:transparent}
:root[data-theme="dark"] .input,
:root[data-theme="dark"] .select,
:root[data-theme="dark"] .textarea{background:#1e293b;color:var(--ink-700);border-color:#334155}
:root[data-theme="dark"] .tbl thead th{background:#1e293b;color:var(--ink-400)}
:root[data-theme="dark"] .tbl tbody td{border-color:#1e293b}
:root[data-theme="dark"] .tbl tbody tr:hover{background:#1e293b}
:root[data-theme="dark"] .btn-secondary{background:#1e293b;color:var(--ink-700);border-color:#334155}
:root[data-theme="dark"] .btn-secondary:hover{background:#334155}
:root[data-theme="dark"] .screen{background:#0f172a}
:root[data-theme="dark"] .appbar,
:root[data-theme="dark"] .stat,
:root[data-theme="dark"] .tabbar{background:#0f172a;border-color:#1e293b;color:var(--ink-700)}
:root[data-theme="dark"] .filter-bar{background:#1e293b;border-color:#334155}
:root[data-theme="dark"] .body-scroll{background:#020617}
:root[data-theme="dark"] .pagination{background:#1e293b;border-color:#334155}
:root[data-theme="dark"] .card-hd{border-color:#1e293b}
:root[data-theme="dark"] .mob-pills,
:root[data-theme="dark"] .mob-pills a{background:#0f172a;border-color:#334155;color:var(--ink-400)}
:root[data-theme="dark"] .mob-pills a.active{background:var(--brand-primary);color:#fff;border-color:transparent}
:root[data-theme="dark"] .doc-h h1,
:root[data-theme="dark"] .page-h h1,
:root[data-theme="dark"] .frame-h h2{color:var(--ink-700)}
:root[data-theme="dark"] .hero{border-color:#1e293b}
:root[data-theme="dark"] .sw,
:root[data-theme="dark"] .swatch{background:#0f172a;border-color:#1e293b}

/* ============================================================ */
/* === v0.3 — LIFECYCLE, NAVIGATION, MINI INDICATORS ========== */
/* ============================================================ */

/* === Lifecycle rozet ailesi (6 durum) === */
/* Tüm CRM aday süreç durumunun "lifecycle" görünümü — A3, dashboard,
   A4 banner, hat uyarıları, sohbet listesi her yerde aynı renk dili */
.lc{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 9px;border-radius:6px;
  font-size:11px;font-weight:600;letter-spacing:.01em;
  border:1px solid transparent;line-height:1.3;
  font-family:'Inter',sans-serif;text-transform:uppercase;
}
.lc .pip{width:6px;height:6px;border-radius:50%;background:currentColor;flex:none}
.lc-yeni{background:#f1f5f9;color:#475569;border-color:#cbd5e1}
.lc-bekliyor{background:#fef3c7;color:#92400e;border-color:#fde68a}
.lc-planlandi{background:#dbeafe;color:#1e40af;border-color:#93c5fd}
.lc-gecti{background:#d1fae5;color:#065f46;border-color:#86efac}
.lc-kaldi{background:#fee2e2;color:#b91c1c;border-color:#fca5a5}
.lc-yandi{
  background:#e2e8f0;color:#475569;border-color:#94a3b8;
  text-decoration:line-through;text-decoration-thickness:1.5px;
  text-decoration-color:rgba(71,85,105,.5);opacity:.85;
}
.lc-yandi .pip{background:#94a3b8;text-decoration:none}

/* === Bekleme nedeni rozeti (7 değer) === */
/* Daha "soft" — durum değil, açıklama; yan rozet olarak kullanılır */
.bn{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px;border-radius:5px;
  font-size:11px;font-weight:500;line-height:1.4;
  border:1px solid transparent;font-style:italic;
}
.bn::before{content:"";width:4px;height:4px;border-radius:50%;background:currentColor;opacity:.55}
.bn-kararsiz{background:#fff7ed;color:#9a3412;border-color:#fed7aa}
.bn-haber{background:#f5f3ff;color:#6d28d9;border-color:#ddd6fe}
.bn-program{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.bn-avrupa{background:#ecfeff;color:#0e7490;border-color:#a5f3fc}
.bn-ofis{background:#fffbeb;color:#854d0e;border-color:#fde68a}
.bn-ildisi{background:#f1f5f9;color:#475569;border-color:#cbd5e1}
.bn-belirsiz{background:#fafafa;color:#52525b;border-color:#e4e4e7}

/* === Hak sayacı === */
.hak{
  display:inline-flex;align-items:center;gap:7px;
  padding:3px 9px;border-radius:6px;
  font-size:11px;font-weight:600;font-family:'JetBrains Mono';
  border:1px solid transparent;
}
.hak.var{background:#fef3c7;color:#92400e;border-color:#fde68a}
.hak.bitti{background:#fee2e2;color:#b91c1c;border-color:#fca5a5}
.hak.full{background:#ecfdf5;color:#047857;border-color:#a7f3d0}
.hak .dots{display:inline-flex;gap:2px}
.hak .dots i{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.25}
.hak .dots i.used{opacity:1}
.hak svg{width:11px;height:11px}

/* === Kalan süre etiketi === */
.kalan{
  display:inline-flex;align-items:center;gap:5px;
  padding:2px 8px;border-radius:5px;
  font-size:11px;font-weight:600;font-family:'JetBrains Mono';
  border:1px solid transparent;
}
.kalan svg{width:11px;height:11px;opacity:.8}
.kalan.gray{background:#f1f5f9;color:#475569;border-color:#e2e8f0}
.kalan.amber{background:#fef3c7;color:#92400e;border-color:#fde68a}
.kalan.red{background:#fee2e2;color:#b91c1c;border-color:#fca5a5}

/* === Kontenjan ince bar === */
.kont{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-family:'JetBrains Mono';color:var(--ink-500)}
.kont .track{width:80px;height:5px;background:var(--ink-100);border-radius:99px;overflow:hidden;flex:none}
.kont .track .fill{height:100%;background:var(--brand-primary);border-radius:99px}
.kont .track .fill.warn{background:var(--warning)}
.kont .track .fill.danger{background:var(--danger)}
.kont .track .fill.ok{background:var(--success)}
.kont b{color:var(--ink-700);font-weight:600}

/* === Top horizontal navigation (8 tab) === */
.app.tn{display:flex;flex-direction:column;min-height:760px;background:#f8fafc}
.app.tn .main{flex:1;min-height:0;background:transparent;display:flex;flex-direction:column}

.tnav{
  height:60px;background:#fff;border-bottom:1px solid var(--ink-100);
  display:flex;align-items:center;gap:0;padding:0 20px;flex:none;
}
.tnav .tn-brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-0.01em;padding-right:18px;margin-right:14px;border-right:1px solid var(--ink-100);height:32px}
.tnav .tn-brand .mk{width:28px;height:28px;border-radius:7px;background:var(--brand-primary);display:grid;place-items:center;color:var(--brand-secondary);font-weight:700;font-size:14px;flex:none}
.tnav .tn-brand-name{font-size:14px;line-height:1}
.tnav .tn-brand-name span{display:block;color:var(--ink-400);font-size:10px;font-weight:500;font-family:'JetBrains Mono';margin-top:3px;text-transform:uppercase;letter-spacing:.06em}

.tnav-tabs{display:flex;gap:1px;flex:1;min-width:0;overflow:visible;align-items:center;flex-wrap:wrap}
.tnav-tabs::-webkit-scrollbar{display:none}
.tnav-tabs > a{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 11px;color:var(--ink-500);text-decoration:none;
  font-size:13px;font-weight:500;border-radius:7px;white-space:nowrap;
  position:relative;line-height:1;
}
.tnav-tabs > a svg{width:14px;height:14px;color:var(--ink-400);flex:none}
.tnav-tabs > a:hover{background:var(--ink-25);color:var(--ink-900)}
.tnav-tabs > a.active{color:var(--brand-primary);background:var(--brand-primary-50);font-weight:600}
.tnav-tabs > a.active svg{color:var(--brand-primary)}
.tnav-tabs > a .num{font-family:'JetBrains Mono';font-size:10px;background:var(--ink-100);color:var(--ink-500);padding:1px 5px;border-radius:99px;font-weight:600;letter-spacing:0}
.tnav-tabs > a.active .num{background:var(--brand-primary);color:#fff}
.tnav-tabs > a.warn .num{background:var(--warning);color:#fff}
.tnav-tabs > a.danger .num{background:var(--danger);color:#fff}
.tnav-tabs > a .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--danger);margin-left:2px}

/* Kategorize edilmiş açılır menü grupları */
.tnav-tabs > .tn-grp{position:relative}
.tnav-tabs > .tn-grp > button{
  display:inline-flex;align-items:center;gap:7px;
  padding:7px 11px;color:var(--ink-500);background:none;border:0;cursor:pointer;
  font-size:13px;font-weight:500;border-radius:7px;white-space:nowrap;
  font-family:inherit;line-height:1;
}
.tnav-tabs > .tn-grp > button svg{width:14px;height:14px;color:var(--ink-400);flex:none}
.tnav-tabs > .tn-grp > button .caret{width:12px;height:12px;transition:transform .15s}
.tnav-tabs > .tn-grp > button:hover{background:var(--ink-25);color:var(--ink-900)}
.tnav-tabs > .tn-grp > button.active{color:var(--brand-primary);background:var(--brand-primary-50);font-weight:600}
.tnav-tabs > .tn-grp > button.active svg{color:var(--brand-primary)}
.tnav-tabs > .tn-grp .num{font-family:'JetBrains Mono';font-size:10px;background:var(--danger);color:#fff;padding:1px 5px;border-radius:99px;font-weight:600;margin-left:1px}
.tn-drop{
  position:absolute;left:0;top:38px;min-width:208px;background:#fff;
  border:1px solid var(--ink-100);border-radius:10px;box-shadow:var(--shadow-3);
  padding:6px;z-index:90;display:flex;flex-direction:column;gap:1px;
}
.tn-drop a{
  display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:7px;
  color:var(--ink-700);text-decoration:none;font-size:13px;font-weight:500;white-space:nowrap;
}
.tn-drop a svg{width:15px;height:15px;color:var(--ink-400);flex:none}
.tn-drop a:hover{background:var(--ink-25);color:var(--ink-900)}
.tn-drop a.active{color:var(--brand-primary);background:var(--brand-primary-50);font-weight:600}
.tn-drop a.active svg{color:var(--brand-primary)}
.tn-drop a .num{font-family:'JetBrains Mono';font-size:10px;background:var(--ink-100);color:var(--ink-500);padding:1px 5px;border-radius:99px;font-weight:600;margin-left:auto}
.tn-drop a.warn .num,.tn-drop a.danger .num{background:var(--danger);color:#fff}

.tnav .tn-right{display:flex;align-items:center;gap:8px;padding-left:12px;margin-left:auto}
/* Komut paleti (Ctrl-K global arama) */
.kp-ov{position:fixed;inset:0;background:rgba(11,18,32,.45);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh}
.kp-box{width:min(620px,92vw);background:#fff;border:1px solid var(--ink-100);border-radius:14px;box-shadow:var(--shadow-3);overflow:hidden;display:flex;flex-direction:column;max-height:70vh}
.kp-box input{border:0;border-bottom:1px solid var(--ink-100);padding:16px 18px;font:inherit;font-size:15px;outline:none}
.kp-list{overflow:auto;padding:6px}
.kp-row{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:8px;text-decoration:none;color:var(--ink-900);cursor:pointer}
.kp-row.sel{background:var(--brand-primary-50)}
.kp-row .kp-tip{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-primary);background:var(--brand-primary-50);padding:3px 7px;border-radius:5px;flex:none;width:78px;text-align:center}
.kp-row b{font-size:13px;font-weight:600;display:block;line-height:1.2}
.kp-row small{font-size:11px;color:var(--ink-500);font-family:'JetBrains Mono'}
.kp-empty{padding:26px;text-align:center;color:var(--ink-400);font-size:13px}
.kp-foot{border-top:1px solid var(--ink-100);padding:7px 14px;font-size:11px;color:var(--ink-400);display:flex;gap:14px}
.kp-trig{display:inline-flex;align-items:center;gap:7px;height:32px;padding:0 12px;border:1px solid var(--ink-200);border-radius:7px;background:var(--ink-25);color:var(--ink-500);font-size:12px;cursor:pointer}
.kp-trig kbd{font-family:'JetBrains Mono';font-size:10px;background:#fff;border:1px solid var(--ink-200);border-radius:4px;padding:1px 5px}
/* Bugün — özet şeridi + tek tip ızgara */
.bugun-ozet{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.bugun-ozet a{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--ink-100);border-radius:10px;padding:10px 14px;text-decoration:none;color:var(--ink-700);min-width:130px;transition:border-color .12s}
.bugun-ozet a:hover{border-color:var(--brand-primary)}
.bugun-ozet .bo-n{font-size:20px;font-weight:700;font-family:'JetBrains Mono';line-height:1}
.bugun-ozet .bo-l{font-size:11px;color:var(--ink-500);font-weight:500}
.bugun-ozet a.warn .bo-n{color:var(--warning)}
.bugun-ozet a.danger .bo-n{color:var(--danger)}
.bugun-ozet a.ok .bo-n{color:var(--ink-300)}
.bugun-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:18px;align-items:start}
@media (max-width:900px){.bugun-grid{grid-template-columns:1fr}}
/* Bugün — tutarlı kompakt liste satırı (tüm kartlarda aynı) */
.bg-list{display:flex;flex-direction:column}
.bg-row{display:flex;align-items:center;gap:10px;padding:9px 16px;border-top:1px solid var(--ink-100)}
.bg-row:first-child{border-top:0}
.bg-row .bg-main{flex:1;min-width:0}
.bg-row .bg-main .fw-500{font-size:13px;line-height:1.25}
.bg-row form{display:flex;margin:0}
.bg-check{width:24px;height:24px;border:1px solid var(--ink-200);background:#fff;border-radius:6px;color:var(--ink-300);cursor:pointer;font-size:12px;line-height:1;flex:none}
.bg-check:hover{border-color:#10b981;color:#10b981;background:#ecfdf5}
.bg-more{display:block;padding:9px 16px;border-top:1px solid var(--ink-100);background:var(--ink-25);text-align:center;color:var(--brand-primary);font-size:12px;text-decoration:none}
.bg-more:hover{background:var(--brand-primary-50)}

/* ── Tasarım sertleştirme (global, eklemeli — şablon değişmez) ── */
/* Klavye erişilebilirliği: tutarlı görünür odak (sadece klavye) */
a:focus-visible,button:focus-visible,[role="button"]:focus-visible,
.btn:focus-visible,.kpi:focus-visible,summary:focus-visible,
[tabindex]:focus-visible{
  outline:2px solid var(--brand-primary);outline-offset:2px;
  border-radius:6px;
}
/* Buton geri-bildirimi + tutarlı pasif durum */
.btn{transition:filter .12s,background .12s,box-shadow .12s}
.btn:active{transform:translateY(1px)}
.btn:disabled,.btn[disabled]{opacity:.5;cursor:not-allowed;
  filter:grayscale(.2)}
/* Tablo yoğunluğu — her ekranda aynı hizalama/ritim */
.tbl td{vertical-align:middle;line-height:1.35}
.tbl tbody tr{transition:background .1s}
/* Tıklanabilir kartlarda tutarlı imleç + hover ipucu */
a.kpi,a.card{cursor:pointer}
/* Marka seçim rengi (cila) */
::selection{background:var(--brand-primary);color:#fff}
/* Hareket hassasiyeti — animasyonları kıs */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    transition-duration:.001ms !important;
  }
}
/* İnce, tutarlı kaydırma çubuğu (içerik alanları) */
.content,.kp-list,.bg-list{scrollbar-width:thin;
  scrollbar-color:var(--ink-200) transparent}
.content::-webkit-scrollbar,
.kp-list::-webkit-scrollbar{width:9px;height:9px}
.content::-webkit-scrollbar-thumb,
.kp-list::-webkit-scrollbar-thumb{
  background:var(--ink-200);border-radius:99px}

/* Kayıtlı görünümler çubuğu */
.kg-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:9px 18px;border-bottom:1px solid var(--ink-100);background:var(--ink-25);font-size:12px}
.kg-lbl{color:var(--ink-500);font-weight:600}
.kg-chip{display:inline-flex;align-items:center;gap:4px;background:#fff;border:1px solid var(--ink-200);border-radius:99px;padding:2px 4px 2px 10px}
.kg-chip a{color:var(--ink-700);text-decoration:none;font-weight:500}
.kg-chip a:hover{color:var(--brand-primary)}
.kg-x{border:0;background:none;color:var(--ink-400);cursor:pointer;font-size:14px;line-height:1;padding:0 3px}
.kg-x:hover{color:var(--danger)}
.kg-bos{color:var(--ink-400)}
.kg-add{border:1px dashed var(--ink-300);background:none;color:var(--ink-500);border-radius:99px;padding:3px 10px;font-size:11px;cursor:pointer}
.kg-add:hover{border-color:var(--brand-primary);color:var(--brand-primary)}
.tnav .tn-search{position:relative;width:200px}
.tnav .tn-search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:13px;height:13px;color:var(--ink-400)}
.tnav .tn-search input{width:100%;height:32px;padding:0 10px 0 30px;border:1px solid var(--ink-200);border-radius:7px;background:var(--ink-25);font:inherit;font-size:12px;outline:none}
.tnav .tn-search .kbd-hint{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:'JetBrains Mono';font-size:10px;color:var(--ink-300);background:#fff;padding:1px 5px;border-radius:3px;border:1px solid var(--ink-100)}
.tnav .tn-me{display:flex;align-items:center;gap:8px;padding-left:10px;margin-left:4px;border-left:1px solid var(--ink-100);height:32px;cursor:pointer}
.tnav .tn-me .who{font-size:12px;line-height:1.2;text-align:right}
.tnav .tn-me .who b{font-weight:600;color:var(--ink-900);display:block}
.tnav .tn-me .who span{font-size:10px;color:var(--ink-400);font-family:'JetBrains Mono';margin-top:1px}

/* === Mobil nav: bottom 4-tab + Daha sheet === */
.tabbar.tabbar-4{grid-template-columns:repeat(4,1fr)}
.tabbar .more-pip{position:absolute;top:4px;right:50%;transform:translateX(18px);width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid #fff}

.daha-sheet{
  position:absolute;left:0;right:0;bottom:0;
  background:#fff;border-radius:22px 22px 0 0;
  box-shadow:0 -12px 40px rgba(15,23,42,.2);
  padding:14px 0 28px;z-index:20;
}
.daha-sheet .grab{width:40px;height:5px;background:var(--ink-200);border-radius:99px;margin:0 auto 14px}
.daha-sheet .ds-h{margin:0;padding:0 24px 10px;font-size:11px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.daha-sheet .opt{display:flex;align-items:center;gap:14px;padding:13px 24px;color:var(--ink-900);text-decoration:none;font-size:14px;font-weight:500;border-top:1px solid var(--ink-100)}
.daha-sheet .opt:first-of-type{border-top:0}
.daha-sheet .opt .ic{width:36px;height:36px;border-radius:9px;background:var(--brand-primary-50);color:var(--brand-primary);display:grid;place-items:center;flex:none}
.daha-sheet .opt .ic svg{width:18px;height:18px}
.daha-sheet .opt .meta{flex:1;min-width:0}
.daha-sheet .opt .sub{font-size:11px;color:var(--ink-400);font-family:'JetBrains Mono';margin-top:2px;font-weight:500}
.daha-sheet .opt .num{font-family:'JetBrains Mono';font-size:11px;color:var(--ink-500);background:var(--ink-50);padding:2px 7px;border-radius:99px}
.daha-sheet .opt.warn .ic{background:var(--danger-50);color:var(--danger)}
.daha-sheet .opt.warn .num{background:var(--danger);color:#fff}
.daha-sheet .opt:active{background:var(--ink-25)}
.daha-sheet .ds-footer{padding:14px 24px 0;color:var(--ink-400);font-size:11px;font-family:'JetBrains Mono';text-align:center}

/* === Mobil: Adaylar altı yatay scroll filtre/yakınlama şeridi === */
.mob-pills{
  flex:none;background:#fff;border-bottom:1px solid var(--ink-100);
  overflow-x:auto;scrollbar-width:none;
}
.mob-pills::-webkit-scrollbar{display:none}
.mob-pills-inner{display:inline-flex;gap:6px;padding:10px 14px}
.mob-pills a{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:99px;
  font-size:12px;font-weight:500;
  color:var(--ink-700);text-decoration:none;white-space:nowrap;
  background:#fff;border:1px solid var(--ink-200);
}
.mob-pills a.active{background:var(--brand-primary);color:#fff;border-color:transparent}
.mob-pills a .num{font-family:'JetBrains Mono';font-size:10px;padding:0 5px;border-radius:99px;background:var(--ink-100);color:var(--ink-500);margin-left:2px;font-weight:600}
.mob-pills a.active .num{background:rgba(255,255,255,.25);color:#fff}
.mob-pills a.warn:not(.active){border-color:#fecaca;color:#b91c1c;background:#fff5f5}
.mob-pills a.warn:not(.active) .num{background:#fee2e2;color:#b91c1c}

/* ====== Uygulama kabuğu + ekran bileşenleri (desktop) ====== */
  /* App chrome */
  .app{display:grid;grid-template-columns:240px 1fr;min-height:760px;background:#f8fafc}
  .side{background:var(--brand-dark);color:#cbd5e1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}
  .side-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:12px}
  .side-brand .mark{width:32px;height:32px;border-radius:8px;background:var(--brand-primary);display:grid;place-items:center;color:var(--brand-secondary);font-weight:700;font-size:15px}
  .side-brand .name{color:#fff;font-weight:600;font-size:15px}
  .side-brand .name span{display:block;color:var(--ink-300);font-size:11px;font-weight:400;font-family:'JetBrains Mono';margin-top:2px;text-transform:uppercase;letter-spacing:.06em}
  .side .group{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:14px 10px 6px;font-weight:600}
  .side a{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;color:#cbd5e1;text-decoration:none;font-size:13px;font-weight:500}
  .side a svg{width:16px;height:16px;flex:none;color:#94a3b8}
  .side a:hover{background:rgba(255,255,255,.06);color:#fff}
  .side a.active{background:var(--brand-primary);color:#fff}
  .side a.active svg{color:var(--brand-secondary)}
  .side a .num{margin-left:auto;font-family:'JetBrains Mono';font-size:11px;background:rgba(255,255,255,.1);padding:1px 6px;border-radius:4px}
  .side .me{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid rgba(255,255,255,.08);margin-top:12px;padding-top:14px}
  .side .me .who{flex:1;font-size:13px;color:#fff;line-height:1.3}
  .side .me .who span{display:block;color:#94a3b8;font-size:11px;font-family:'JetBrains Mono';margin-top:1px}

  .main{display:flex;flex-direction:column;min-width:0}
  .top{height:56px;background:#fff;border-bottom:1px solid var(--ink-100);display:flex;align-items:center;gap:16px;padding:0 24px;flex:none}
  .top .crumbs{font-size:13px;color:var(--ink-500);display:flex;gap:8px;align-items:center}
  .top .crumbs b{color:var(--ink-900);font-weight:500}
  .top .top-search{margin-left:auto;width:320px;position:relative}
  .top .top-search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--ink-400)}
  .top .top-search input{width:100%;height:36px;padding:0 12px 0 34px;border:1px solid var(--ink-200);border-radius:8px;background:#f8fafc;font:inherit;font-size:13px;outline:none}
  .top .top-search input::placeholder{color:var(--ink-300)}
  .top .top-actions{display:flex;align-items:center;gap:6px}
  .top-icon-btn{width:36px;height:36px;border-radius:8px;border:0;background:transparent;display:grid;place-items:center;color:var(--ink-500);cursor:pointer;position:relative}
  .top-icon-btn:hover{background:var(--ink-50);color:var(--ink-900)}
  .top-icon-btn .dot{position:absolute;top:8px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid #fff}
  .content{padding:24px 28px;flex:1;min-width:0;overflow:hidden}
  .page-h{display:flex;align-items:flex-end;gap:16px;margin-bottom:20px}
  .page-h h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-0.01em}
  .page-h .sub{color:var(--ink-400);font-size:13px;margin-top:2px}
  .page-h .right{margin-left:auto;display:flex;gap:8px}

  /* Dashboard specifics */
  .kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
  .dash-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:20px}

  .urgent-row{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--ink-100)}
  .urgent-row:last-child{border-bottom:0}
  .urgent-row .age{font-family:'JetBrains Mono';font-size:11px;color:#b91c1c;background:var(--danger-50);padding:3px 7px;border-radius:4px;font-weight:500;border:1px solid #fecaca}
  .urgent-row .snip{color:var(--ink-500);font-size:12px;margin-top:2px}
  .urgent-row .name{font-size:13px;font-weight:500}

  /* Conversion funnel */
  .funnel{display:flex;flex-direction:column;gap:10px;padding:18px}
  .funnel-row{display:flex;align-items:center;gap:12px;font-size:13px}
  .funnel-row .lbl{width:100px;color:var(--ink-500)}
  .funnel-row .bar{flex:1;height:24px;border-radius:6px;background:var(--ink-50);position:relative;overflow:hidden}
  .funnel-row .bar .fill{height:100%;background:linear-gradient(90deg,#1e3a8a,#3b5bdb);border-radius:6px;display:flex;align-items:center;padding:0 10px;color:#fff;font-weight:500;font-size:12px;font-family:'JetBrains Mono'}
  .funnel-row .pct{width:50px;text-align:right;font-family:'JetBrains Mono';color:var(--ink-500);font-size:12px}

  /* Filter bar */
  .filter-bar{display:flex;gap:10px;padding:14px 18px;border-bottom:1px solid var(--ink-100);background:#fafbfd;align-items:center;flex-wrap:wrap}
  .filter-bar .input-icon{flex:1;min-width:240px;max-width:340px}
  .filter-bar .select{min-width:140px;flex:0 0 auto;width:auto;height:38px;padding-right:32px}
  .filter-chip{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--ink-200);padding:7px 10px;border-radius:8px;font-size:13px;color:var(--ink-700);cursor:pointer}
  .filter-chip svg{width:13px;height:13px;color:var(--ink-400)}

  .pagination{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;font-size:13px;color:var(--ink-500);border-top:1px solid var(--ink-100);background:#fafbfd}
  .pagination .pager{display:flex;gap:6px}
  .pg-btn{width:30px;height:30px;display:grid;place-items:center;border:1px solid var(--ink-200);background:#fff;border-radius:6px;font-size:12px;cursor:pointer;color:var(--ink-500);font-family:'JetBrains Mono'}
  .pg-btn.active{background:var(--brand-primary);border-color:transparent;color:#fff}
  .pg-btn.arrow{width:auto;padding:0 10px;color:var(--ink-700)}

  /* Aday detay banner */
  .ad-banner{display:flex;gap:18px;align-items:center;background:linear-gradient(135deg,#1e3a8a 0%,#172f6f 100%);color:#fff;padding:20px 24px;border-radius:12px;position:relative;overflow:hidden}
  .ad-banner::after{content:"";position:absolute;right:-100px;top:-50px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(245,158,11,.15),transparent 70%)}
  .ad-banner .nm{font-size:22px;font-weight:600;letter-spacing:-0.01em}
  .ad-banner .meta-row{display:flex;gap:18px;color:#bfdbfe;font-size:13px;margin-top:6px;flex-wrap:wrap;align-items:center}
  .ad-banner .meta-row .sep{color:#475569;width:1px;height:14px;background:#3b5bdb}
  .ad-banner .right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:8px;position:relative;z-index:1}
  .ad-banner .last-act{font-size:11px;color:#cbd5e1;font-family:'JetBrains Mono';text-transform:uppercase;letter-spacing:.06em}

  .tabs{display:flex;border-bottom:1px solid var(--ink-100);margin-top:18px}
  .tabs .t{padding:11px 16px;font-size:13px;color:var(--ink-500);cursor:pointer;font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:8px}
  .tabs .t.active{color:var(--brand-primary);border-bottom-color:var(--brand-primary)}
  .tabs .t .ct{background:var(--ink-100);color:var(--ink-500);font-size:11px;padding:1px 6px;border-radius:99px;font-family:'JetBrains Mono'}

  .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:18px}
  .info-card{background:#fff;border:1px solid var(--ink-100);border-radius:12px;padding:20px;box-shadow:var(--shadow-1)}
  .info-card h3{margin:0 0 14px;font-size:13px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;font-weight:600;display:flex;align-items:center;gap:8px}
  .info-card h3::before{content:"";width:3px;height:14px;background:var(--brand-primary);border-radius:2px}
  .info-row{display:grid;grid-template-columns:130px 1fr;gap:14px;padding:8px 0;border-bottom:1px dashed var(--ink-100);font-size:13px}
  .info-row:last-child{border:0}
  .info-row .key{color:var(--ink-400)}
  .info-row .val{color:var(--ink-900);font-weight:500}

  .stars{display:inline-flex;gap:2px;color:var(--brand-secondary)}

  /* Inbox — viewport'a sabit yükseklik; iki kolon BAĞIMSIZ kayar */
  .inbox{display:grid;grid-template-columns:340px 1fr;height:calc(100dvh - 104px);overflow:hidden}
  .inbox-list,.inbox .chat-pane{min-height:0;overflow:hidden}
  .convo-back{display:none}
  .inbox-list{border-right:1px solid var(--ink-100);display:flex;flex-direction:column;background:#fff;min-width:0}
  .inbox-list .inbox-h{padding:18px 18px 10px;display:flex;align-items:center;gap:10px}
  .inbox-list .inbox-h h2{margin:0;font-size:16px;font-weight:600}
  .inbox-list .inbox-h .ct{background:var(--brand-primary-50);color:var(--brand-primary);font-size:11px;padding:2px 7px;border-radius:99px;font-family:'JetBrains Mono';font-weight:600}
  .inbox-list .inbox-filter{padding:0 18px 12px;display:flex;gap:6px;flex-wrap:wrap}
  .inbox-list .inbox-search{padding:0 18px 12px}
  .inbox-row{display:flex;gap:12px;padding:12px 18px;border-bottom:1px solid var(--ink-100);cursor:pointer;position:relative}
  .inbox-row:hover{background:var(--ink-25)}
  .inbox-row.active{background:var(--brand-primary-50)}
  .inbox-row.active::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--brand-primary)}
  .inbox-row .body{flex:1;min-width:0}
  .inbox-row .top-line{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
  .inbox-row .nm{font-size:13px;font-weight:600;color:var(--ink-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .inbox-row .tm{font-size:11px;color:var(--ink-400);font-family:'JetBrains Mono';flex:none}
  .inbox-row .snip{font-size:12px;color:var(--ink-500);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .inbox-row .meta{display:flex;gap:6px;margin-top:6px;align-items:center}
  .inbox-row .unread{position:absolute;right:18px;top:46px;width:8px;height:8px;border-radius:50%;background:var(--danger)}

  /* WhatsApp-tarzı: cream/warm chat alanı + WhatsApp header rengi */
  .chat-pane{display:flex;flex-direction:column;background:#efeae2;min-width:0}
  .chat-h{display:flex;gap:12px;align-items:center;padding:10px 16px;border-bottom:1px solid rgba(15,23,42,.06);background:#f0f2f5;flex:none}
  .chat-h .nm{font-size:15px;font-weight:600;color:#111b21}
  .chat-h .sub{font-size:12px;color:#667781;font-family:inherit}
  .chat-h .acts{margin-left:auto;display:flex;gap:6px;align-items:center}

  /* Sohbet gövdesi — WhatsApp doodle yerine düz cream (sade & hızlı) */
  .chat-body{flex:1;overflow-y:auto;padding:14px 6%;display:flex;flex-direction:column;gap:3px;min-height:0;background:#efeae2}

  /* Input alanı — WhatsApp pill-input */
  .chat-input{padding:8px 12px;border-top:none;background:#f0f2f5;display:flex;gap:8px;align-items:flex-end}
  .chat-input textarea{
    flex:1;border:none;border-radius:22px;
    padding:11px 16px;font:inherit;font-size:14.5px;
    resize:none;min-height:42px;max-height:120px;
    background:#fff;box-shadow:0 1px 1px rgba(0,0,0,.04);
  }
  .chat-input textarea:focus{outline:none;box-shadow:0 0 0 1px rgba(0,168,132,.35)}
  .chat-input .btn-primary{
    background:#00a884;border-color:#00a884;color:#fff;
    width:44px;height:44px;border-radius:50%;padding:0;flex:none;
    display:flex;align-items:center;justify-content:center;
  }
  .chat-input .btn-primary:hover{background:#039372;border-color:#039372}
  .chat-input .btn-primary svg{margin:0}
  /* Evrak/görsel ekleme butonu — input'un sol yanında, ikon-only, gri */
  .chat-input .btn-attach{
    background:transparent;border:none;width:42px;height:42px;
    border-radius:50%;padding:0;flex:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    color:#54656f;
  }
  .chat-input .btn-attach:hover{background:rgba(0,0,0,.05);color:#111b21}
  .chat-warn{font-size:11px;color:#92400e;background:var(--warning-50);padding:6px 14px;border-bottom:1px solid #fde68a;display:flex;align-items:center;gap:8px;font-family:'JetBrains Mono';text-transform:uppercase;letter-spacing:.04em}

  /* Login */
  .login-stage{
    background:radial-gradient(circle at 20% 20%, #2d4ea8 0%, #1e3a8a 35%, #1e293b 100%);
    height:760px;display:grid;place-items:center;position:relative;overflow:hidden;
  }
  .login-stage::before{
    content:"";position:absolute;width:600px;height:600px;border-radius:50%;
    background:radial-gradient(circle,rgba(245,158,11,.18),transparent 60%);
    top:-200px;right:-150px;
  }
  .login-stage::after{
    content:"";position:absolute;width:400px;height:400px;border-radius:50%;
    background:radial-gradient(circle,rgba(59,91,219,.25),transparent 60%);
    bottom:-100px;left:-100px;
  }
  .login-card{
    width:420px;background:#fff;border-radius:16px;padding:36px;
    box-shadow:0 30px 60px -10px rgba(0,0,0,.4);z-index:1;
  }
  .login-card .lk-brand{display:flex;align-items:center;gap:12px;margin-bottom:24px}
  .login-card .lk-brand .mark{width:44px;height:44px;border-radius:10px;background:var(--brand-primary);display:grid;place-items:center;color:var(--brand-secondary);font-weight:700;font-size:22px}
  .login-card h1{margin:0;font-size:22px;font-weight:600;letter-spacing:-0.01em}
  .login-card .sub{color:var(--ink-400);font-size:13px;margin-top:4px}
  .login-card form{display:flex;flex-direction:column;gap:14px;margin-top:24px}
  .login-card .helper{font-size:12px;color:var(--ink-400);text-align:center;margin-top:14px}

  /* Filter dropdown demo */
  .filter-chip.act{background:var(--brand-primary-50);border-color:#c7d2fe;color:var(--brand-primary)}

  /* Sparkline tiny */
  svg.spark.tiny{height:24px}

  /* A4 Konuşma tab — single chat pane */
  .a4-chat{display:grid;grid-template-columns:1fr 320px;gap:0;background:#fff;border:1px solid var(--ink-100);border-radius:12px;overflow:hidden;margin-top:18px;height:580px;box-shadow:var(--shadow-1)}
  .a4-chat .left{display:flex;flex-direction:column;border-right:1px solid var(--ink-100);min-width:0}
  .a4-chat .right{padding:18px;background:#fafbfd;display:flex;flex-direction:column;gap:14px;overflow-y:auto;font-size:13px}
  .a4-chat .right h4{margin:0 0 8px;font-size:11px;color:var(--ink-500);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
  .a4-chat .right .kv{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px dashed var(--ink-100);font-size:12px}
  .a4-chat .right .kv:last-child{border:0}
  .a4-chat .right .kv .k{color:var(--ink-400)}
  .a4-chat .right .kv .v{color:var(--ink-900);font-weight:500}
  .a4-chat .right .block{background:#fff;border:1px solid var(--ink-100);border-radius:10px;padding:14px}
  .a4-chat .right .qa{display:flex;gap:8px;align-items:flex-start;padding:8px 0;border-bottom:1px dashed var(--ink-100);font-size:12px;line-height:1.4}
  .a4-chat .right .qa:last-child{border:0}
  .a4-chat .right .qa .dot{width:8px;height:8px;border-radius:50%;background:var(--brand-secondary);flex:none;margin-top:5px}

  /* A4 Süreç sekmesi — timeline + doc + sınav */
  .surec-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;margin-top:18px}
  .timeline{padding:8px 22px 22px;position:relative}
  .timeline::before{content:"";position:absolute;left:36px;top:18px;bottom:18px;width:2px;background:var(--ink-100)}
  .tl-item{display:grid;grid-template-columns:36px 1fr auto;gap:14px;align-items:flex-start;padding:14px 0;position:relative}
  .tl-dot{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:#fff;border:2px solid var(--ink-100);color:var(--ink-400);position:relative;z-index:1}
  .tl-dot svg{width:16px;height:16px}
  .tl-dot.ok{background:var(--success-50);border-color:#a7f3d0;color:#047857}
  .tl-dot.warn{background:var(--warning-50);border-color:#fde68a;color:#92400e}
  .tl-dot.info{background:var(--brand-primary-50);border-color:#c7d2fe;color:var(--brand-primary)}
  .tl-dot.dim{background:var(--ink-25);border-color:var(--ink-100);color:var(--ink-300)}
  .tl-body .ttl{font-weight:600;font-size:14px;color:var(--ink-900)}
  .tl-body .desc{color:var(--ink-500);font-size:12px;margin-top:3px;line-height:1.5}
  .tl-body .who{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-size:11px;color:var(--ink-400)}
  .tl-time{font-family:'JetBrains Mono';font-size:11px;color:var(--ink-400);white-space:nowrap;padding-top:4px}

  /* doc cards */
  .doc-card{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;border:1px solid var(--ink-100);border-radius:10px}
  .doc-card .ic{width:40px;height:48px;border-radius:6px;display:grid;place-items:center;font-size:9px;font-family:'JetBrains Mono';font-weight:700;letter-spacing:.04em;flex:none}
  .doc-card .ic.pdf{background:#fee2e2;color:#b91c1c}
  .doc-card .ic.jpg{background:#dbeafe;color:#1e40af}
  .doc-card .ic.docx{background:#dbeafe;color:#1e40af}
  .doc-card .meta{flex:1;min-width:0}
  .doc-card .nm{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .doc-card .sub{font-size:11px;color:var(--ink-400);font-family:'JetBrains Mono';margin-top:2px}

/* ============================================================ */
/* === Planlama — Google Takvim tarzı ay ızgarası ============= */
/* ============================================================ */
.cal{background:var(--paper);border:1px solid var(--ink-100);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-1)}
.cal-bar{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--ink-100);flex-wrap:wrap}
.cal-bar .mon{font-size:16px;font-weight:600;min-width:150px;text-align:center}
.cal-nav{width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--ink-200);background:#fff;border-radius:8px;color:var(--ink-600,#475569);cursor:pointer;text-decoration:none}
.cal-nav:hover{background:var(--ink-25)}
.cal-head,.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-head>div{padding:8px 6px;text-align:center;font-size:11px;font-weight:600;color:var(--ink-400);text-transform:uppercase;letter-spacing:.04em;background:var(--ink-25);border-bottom:1px solid var(--ink-100)}
.cal-cell{min-height:104px;border-right:1px solid var(--ink-100);border-bottom:1px solid var(--ink-100);padding:6px 6px 8px;display:flex;flex-direction:column;gap:4px;overflow:hidden}
.cal-cell:nth-child(7n){border-right:0}
.cal-cell .d{font-size:12px;font-weight:600;color:var(--ink-500);font-family:'JetBrains Mono';align-self:flex-end}
.cal-cell.out{background:var(--ink-25)}
.cal-cell.out .d{color:var(--ink-300)}
.cal-cell.today{background:var(--brand-primary-50)}
.cal-cell.today .d{background:var(--brand-primary);color:#fff;border-radius:50%;width:20px;height:20px;display:grid;place-items:center}
.cal-ev{display:block;font-size:11px;line-height:1.3;padding:2px 6px;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-decoration:none;border:1px solid transparent}
.cal-ev.sinav{background:var(--brand-primary-50);color:var(--brand-primary);border-color:#c7d2fe}
.cal-ev.etkinlik{background:var(--warning-50);color:#92400e;border-color:#fde68a}
.cal-ev.gecmis{opacity:.5}
.cal-more{font-size:10px;color:var(--ink-400);padding:0 6px;font-family:'JetBrains Mono'}
.view-switch{display:inline-flex;background:var(--ink-50);border-radius:8px;padding:2px;gap:0}
.view-switch a{padding:6px 14px;font-size:13px;border-radius:6px;text-decoration:none;color:var(--ink-500);font-weight:500}
.view-switch a.active{background:#fff;color:var(--brand-primary);box-shadow:var(--shadow-1);font-weight:600}
@media (max-width:640px){.cal-cell{min-height:72px}.cal-ev{font-size:10px}}

/* ============================================================ */
/* === Mobil responsive (≤768px) — planlamacı sahada telefon == */
/* ============================================================ */
@media (max-width:768px){
  /* Üst nav: arama gizle, marka kısalt, sekmeler kaydırılır */
  .tnav{height:54px;padding:0 12px}
  .tnav .tn-brand{padding-right:10px;margin-right:8px}
  .tnav .tn-brand-name span{display:none}
  .tnav .tn-search{display:none}
  .tnav .tn-me .who{display:none}
  .tnav-tabs>a{padding:7px 9px;font-size:12px}
  .tnav-tabs>a .num{display:none}

  /* İçerik kenar boşluğu daralt */
  .content{padding:16px 14px !important}
  .top{padding:0 14px !important}
  .page-h{flex-direction:column;align-items:flex-start;gap:10px}
  .page-h .right{margin-left:0;width:100%;flex-wrap:wrap}

  /* Grid'ler tek kolona */
  .info-grid{grid-template-columns:1fr !important}
  .kpi-row{grid-template-columns:1fr 1fr !important}
  .dash-grid{grid-template-columns:1fr !important}
  .surec-grid{grid-template-columns:1fr !important}

  /* Aday detay banner dikey */
  .ad-banner{flex-direction:column;align-items:flex-start;gap:14px}
  .ad-banner .right{align-items:flex-start;margin-left:0}

  /* Konuşmalar mobil: TEK ekran — ya liste ya sohbet (WhatsApp tarzı).
     iPhone home-indicator safe-area'sını da hesaba kat → chat-input
     alttaki .mtab arkasına gizlenmesin. */
  .inbox{grid-template-columns:1fr !important;height:calc(100dvh - 54px - 60px - env(safe-area-inset-bottom, 0px)) !important}

  /* Sohbete girilince WhatsApp tam-ekran: alt nav (.mtab) gizlenir,
     .main padding-bottom sıfırlanır, .inbox topnav hariç tüm yüksekliği
     alır. has() ile sayfa-koşullu — diğer ekranlarda nav kalır. */
  .app.tn:has(.inbox.has-sel) .mtab{display:none !important}
  .app.tn:has(.inbox.has-sel) .main{padding-bottom:0 !important}
  .app.tn:has(.inbox.has-sel) .inbox{height:calc(100dvh - 54px - env(safe-area-inset-bottom, 0px)) !important}
  /* .chat-pane-detay mobil chat-input offset'i de kalksın (aday detay
     da gibi sticky-input olan başka durumlar için): mtab gizliyken
     bottom 0'a oturmalı. */
  .app.tn:has(.inbox.has-sel) .chat-pane-detay .chat-input{bottom:0 !important}

  /* Sohbet başlığı dar ekranda sıkışmasın: padding daralt, telefon tek
     satır + ellipsis, aksiyonlar wrap'lansın. */
  .chat-h{padding:8px 12px;gap:8px;flex-wrap:wrap}
  .chat-h .sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60vw}
  .chat-h .acts{margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
  .chat-h .acts .btn{padding:5px 9px;font-size:11px}
  .chat-h .avatar{width:36px;height:36px;font-size:12px}
  .inbox .inbox-list{max-height:none;display:flex}
  .inbox .chat-pane{display:none}
  .inbox.has-sel .inbox-list{display:none}
  .inbox.has-sel .chat-pane{display:flex}
  .convo-back{display:inline-flex !important}

  /* Filtre çubuğu sarılır, kartlar tam genişlik */
  .filter-bar{flex-direction:column;align-items:stretch}
  .filter-bar .input-icon,.filter-bar .select,.filter-bar .input{max-width:none !important;width:100% !important}
  .card{margin-left:0 !important;margin-right:0 !important}

  /* Tablo: dar ekranda yatay kaydırma + .col-hide-sm sınıflı kolonlar
     gizlenir (önceliği düşük yardımcı kolonlar bu sınıfla işaretlenir) */
  .card>.tbl,.card>div>.tbl{display:block;overflow-x:auto}
  .col-hide-sm{display:none !important}
  /* Tabloda padding'leri sıkıştır */
  .tbl thead th,.tbl tbody td{padding:9px 10px;font-size:12px}

  /* Mobil — inline min-width değerleri (240px+ vb. desktop için konmuş)
     form elemanlarında overflow yapmasın. */
  input.input,select.select,textarea.textarea{min-width:0 !important}
  /* Touch hedef sertleştirmesi */
  .btn-sm{min-height:34px}
  /* Form satırı: birden çok input yan yana → mobilde alt alta */
  form[style*="display:flex"]:not(.no-wrap-mobile){flex-wrap:wrap}

  /* Modal/orta kartlar tam genişlik */
  .login-card{width:100%}

  /* Takvim hücreleri sıkış */
  .cal-bar{justify-content:center}
  .cal-cell{min-height:64px;padding:4px}
  .cal-cell .d{font-size:11px}
}

/* Çok dar (≤420px) — KPI tek kolon */
@media (max-width:420px){
  .kpi-row{grid-template-columns:1fr !important}
  .tabs .t{padding:10px 10px;font-size:12px}
}

/* ============================================================ */
/* === B7 Sınav Sonuç (Claude Design phase2.html — birebir) ==== */
/* ============================================================ */
.b2-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:20px}
.b7-row{display:grid;grid-template-columns:1fr 96px 264px 210px;gap:12px;padding:14px 18px;border-bottom:1px solid var(--ink-100);align-items:center}
.b7-row:last-child{border-bottom:0}
.b7-aday{display:flex;align-items:center;gap:12px;min-width:0}
.b7-score{position:relative}
.b7-score input{width:88px;height:34px;padding:0 30px 0 10px;border:1px solid var(--ink-200);border-radius:6px;font:inherit;font-size:13px;font-family:'JetBrains Mono';text-align:right;outline:none;background:#fff}
.b7-score input:focus{border-color:var(--brand-primary);box-shadow:0 0 0 3px rgba(30,58,138,.12)}
.b7-score .max{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:10px;color:var(--ink-400);font-family:'JetBrains Mono';pointer-events:none}
.b7-status{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:6px;font-size:11px;font-weight:500;line-height:1.3;white-space:nowrap}
.b7-status.green{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}
.b7-status.blue{background:#dbeafe;color:#1e40af;border:1px solid #93c5fd}
.b7-status.gray{background:transparent;color:var(--ink-300);font-style:italic}
.b7-status.pending{background:var(--ink-50);color:var(--ink-500);border:1px solid var(--ink-200);font-style:italic}
.b7-status svg{width:11px;height:11px;flex:none}
.seg-btn{display:flex;background:var(--ink-50);border-radius:8px;padding:3px;border:1px solid var(--ink-100)}
.seg-btn label{flex:1;text-align:center;padding:6px 0;font-size:12px;color:var(--ink-500);cursor:pointer;border-radius:6px;font-weight:500;user-select:none}
.seg-btn label.pass{color:#047857}
.seg-btn label.fail{color:#b91c1c}
.seg-btn label.no{color:#92400e}
.seg-btn label.act-pass{background:#10b981;color:#fff}
.seg-btn label.act-fail{background:#ef4444;color:#fff}
.seg-btn label.act-no{background:#f59e0b;color:#fff}
.seg-btn input{position:absolute;opacity:0;pointer-events:none}
@media (max-width:768px){.b2-grid{grid-template-columns:1fr 1fr}.b7-row{grid-template-columns:1fr;gap:8px}}

/* ============================================================ */
/* === Mobil alt tab bar + Daha sheet (tasarım mobile.html) === */
/* ============================================================ */
.mtab,.msheet,.msheet-bg{display:none}
/* _topnav Alpine kökü layout'u etkilemesin — çocuklar .app.tn flex'ine girsin */
.app.tn > div[x-data]{display:contents}
/* Hamburger — masaüstünde gizli */
.tnav-burger{display:none;width:38px;height:38px;border:0;background:transparent;border-radius:8px;color:var(--ink-700);cursor:pointer;align-items:center;justify-content:center;flex:none;margin-right:4px}
.tnav-burger svg{width:22px;height:22px}
.tnav-burger:hover{background:var(--ink-50)}
@media (max-width:860px){
  .tnav-tabs{display:none !important}        /* üst sekme şeridi gizle */
  .tnav-burger{display:inline-flex}          /* hamburger görünür */
  .tnav .tn-search{display:none}
  .app.tn .main{padding-bottom:calc(66px + env(safe-area-inset-bottom,0px))}

  .mtab{
    display:grid;grid-template-columns:repeat(4,1fr);
    position:fixed;left:0;right:0;bottom:0;z-index:70;
    height:calc(60px + env(safe-area-inset-bottom,0px));
    padding-bottom:env(safe-area-inset-bottom,0px);
    background:#fff;border-top:1px solid var(--ink-100);
    box-shadow:0 -4px 16px rgba(15,23,42,.10);
  }
  .mtab a,.mtab button{
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;color:var(--ink-400);text-decoration:none;font-size:10px;font-weight:600;
    position:relative;background:none;border:0;cursor:pointer;font-family:inherit;
  }
  .mtab a svg,.mtab button svg{width:22px;height:22px}
  .mtab .active{color:var(--brand-primary)}

  .msheet-bg{display:block;position:fixed;inset:0;background:rgba(11,18,32,.45);z-index:88}
  .msheet{
    display:block;position:fixed;left:0;right:0;bottom:0;z-index:90;
    background:#fff;border-radius:20px 20px 0 0;padding:12px 0 24px;
    box-shadow:0 -12px 40px rgba(15,23,42,.25);max-height:80vh;overflow-y:auto;
  }
  .msheet .grab{width:40px;height:5px;background:var(--ink-200);border-radius:99px;margin:0 auto 12px}
  .msheet .ds-h{margin:0;padding:0 22px 8px;font-size:11px;color:var(--ink-400);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
  .msheet a{display:flex;align-items:center;gap:14px;padding:13px 22px;color:var(--ink-900);text-decoration:none;font-size:14px;font-weight:500;border-top:1px solid var(--ink-100)}
  .msheet a .ic{width:34px;height:34px;border-radius:9px;background:var(--brand-primary-50);color:var(--brand-primary);display:grid;place-items:center;flex:none}
  .msheet a .ic svg{width:18px;height:18px}
  .msheet a .num{margin-left:auto;font-family:'JetBrains Mono';font-size:11px;background:var(--ink-50);color:var(--ink-500);padding:2px 7px;border-radius:99px}
  .msheet a.warn .ic{background:var(--danger-50);color:var(--danger)}
  .msheet a.warn .num{background:var(--danger);color:#fff}
  .msheet a.active{color:var(--brand-primary)}
}

/* ============================================================ */
/* === Modal overlay (tasarım: Yeni Aday / Sınav-Etkinlik Ekle) */
/* ============================================================ */
.modal-ov{position:fixed;inset:0;z-index:70;background:rgba(11,18,32,.45);backdrop-filter:blur(2px);display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow-y:auto}
.modal-card{width:540px;max-width:100%;background:#fff;border-radius:14px;box-shadow:0 30px 60px -10px rgba(0,0,0,.3);overflow:hidden;animation:modalIn .16s ease-out}
@keyframes modalIn{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}
.modal-hd{padding:18px 22px;border-bottom:1px solid var(--ink-100);display:flex;align-items:center;gap:10px}
.modal-hd h3{margin:0;font-size:17px;font-weight:600;letter-spacing:-0.01em}
.modal-hd .x{margin-left:auto;width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--ink-400);text-decoration:none;border:0;background:transparent;cursor:pointer}
.modal-hd .x:hover{background:var(--ink-50);color:var(--ink-900)}
.modal-bd{padding:20px 22px;display:flex;flex-direction:column;gap:14px;max-height:calc(100vh - 230px);overflow-y:auto}
.modal-ft{padding:14px 22px;border-top:1px solid var(--ink-100);display:flex;gap:10px;background:var(--ink-25)}
@media (max-width:768px){.modal-ov{padding:0;align-items:stretch}.modal-card{width:100%;max-width:none;border-radius:0;min-height:100vh}.modal-bd{max-height:none}}
