/* ============================================================
   Dr. Matcha — Design System (ds.css)  ·  TEK KAYNAK / single source
   index.html ve app.html bunu <link> ile çeker.

   KURAL: Yeni UI yaparken önce buradaki bir class'ı kullan. Gereken
   komponent yoksa BURAYA adlı bir komponent olarak ekle, sonra kullan.
   Aynı/benzer eleman için ASLA yeni/farklı stil uydurma.
   Magic number yerine aşağıdaki --radius-* / --space-* / --fs-* token'larını kullan.
   Envanter + ne-nerede kuralı: ../CLAUDE.md "UI / Design System".
   ============================================================ */

:root {
  /* ---- renk (iki dosyanın birleşik token seti) ---- */
  --bg: #0e0e11;
  --surface: #17171c;
  --surface-2: #1f1f26;
  --line: #2c2c36;
  --line-soft: #232329;
  --ink: #f2f2f5;
  --ink-soft: #9a9aa6;
  --ink-faint: #66666f;
  --accent: #E5FF55;
  --accent-ink: #0e0e11;
  --link: #E8CF7A;
  --warn: #ffb13f;
  --danger: #ff5a5a;
  --ok: #5ad19a;
  --done: #E5FF55;          /* app.html çember/done rengi (= accent) */
  --mono: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace;
  --sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, sans-serif;

  /* ---- ölçek token'ları (magic number'ları bitirir — YENİ iş bunları kullansın) ---- */
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 999px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --fs-xs: 11px;
  --fs-sm: 12px;
  --fs-base: 14px;
  --fs-lg: 16px;
  --fs-xl: 20px;
  --fs-2xl: 28px;
}

/* ---- tipografi ---- */
.eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; color: var(--ink-faint); text-transform: uppercase; margin-bottom: 8px; }
.eyebrow.accent { color: var(--accent); }
.eyebrow + * { margin-top: 0; }
.title { font-size: 28px; font-weight: 680; letter-spacing: -0.02em; line-height: 1.05; margin-top: 8px; }
.title span { color: var(--accent); }
.sub { color: var(--ink-soft); font-size: 14px; line-height: 1.5; }
.muted { color: var(--ink-soft); }
.faint { color: var(--ink-faint); }
.mono { font-family: var(--mono); }

/* ---- buton ---- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--surface-2); color: var(--ink);
  border: 1px solid var(--line); border-radius: 10px;
  padding: 10px 16px; font-size: 14px; font-weight: 500; font-family: var(--sans);
  transition: border-color .15s, background .15s;
}
.btn:hover { border-color: #3a3a46; }
.btn-primary { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.btn-primary:hover { filter: brightness(1.05); border-color: var(--accent); }
.btn-ghost { background: transparent; }
.btn-danger { color: var(--danger); border-color: #3a2730; }
.btn-danger:hover { background: #2a1c22; border-color: var(--danger); }
.btn-warn { color: var(--warn); border-color: #3a3018; }
.btn-warn:hover { background: #2e2410; border-color: var(--warn); }
.btn-block { width: 100%; justify-content: center; margin-top: 12px; }
.btn-sm { padding: 6px 10px; font-size: 12px; border-radius: 8px; }
.btn:disabled { opacity: .5; cursor: not-allowed; }
.btn:disabled:hover { filter: none; }
/* "Tümünü Kapat/Aç" — iki etiket arası geçişte genişlik en uzun metne sabit, buton zıplamaz */
.btn-toggle { display: inline-block; text-align: center; }
.btn-toggle::before { content: "Tümünü Kapat"; display: block; height: 0; overflow: hidden; visibility: hidden; pointer-events: none; }

/* ---- form ---- */
.field { display: block; margin-bottom: 14px; }
.field > label { display: block; font-size: 12px; font-weight: 600; color: var(--ink-soft); margin-bottom: 6px; }
.field .hint { font-size: 11px; color: var(--ink-faint); margin-top: 4px; line-height: 1.4; }
.input, .textarea, select.input {
  width: 100%; background: var(--bg); color: var(--ink);
  border: 1px solid var(--line); border-radius: 10px;
  padding: 10px 12px; font-size: 14px; outline: none;
  transition: border-color .15s;
}
.input::placeholder, .textarea::placeholder { color: var(--ink-soft); opacity: .42; }
.input:focus, .textarea:focus, select.input:focus { border-color: var(--accent); }
.input.invalid, .input.invalid:focus {
  border-color: var(--danger);
  box-shadow: 0 0 0 3px rgba(255,90,90,.16);
}
.input.shake { animation: inputShake .42s cubic-bezier(.36,.07,.19,.97); }
@keyframes inputShake {
  10%,90% { transform: translateX(-1px); }
  20%,80% { transform: translateX(2px); }
  30%,50%,70% { transform: translateX(-5px); }
  40%,60% { transform: translateX(5px); }
}
.textarea { resize: vertical; min-height: 90px; font-family: var(--mono); font-size: 12.5px; line-height: 1.5; }
.row { display: flex; gap: 12px; }
.row > * { flex: 1; }

/* ---- yüzey ---- */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 20px; }
.card + .card { margin-top: 24px; }

/* ---- toast ---- */
.toast {
  position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%) translateY(20px);
  background: var(--surface-2); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 18px; font-family: var(--sans); font-size: 13px; color: var(--ink);
  opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s; z-index: 50;
  box-shadow: 0 8px 30px rgba(0,0,0,.4);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.err { border-color: var(--danger); color: #fff; }
.toast.ok { border-color: var(--ok); color: #fff; }

/* ---- checkbox satırı ---- */
.checkrow { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink-soft); cursor: pointer; user-select: none; }
.checkrow input {
  appearance: none; -webkit-appearance: none; flex: none; margin: 0;
  width: 20px; height: 20px; border-radius: 6px;
  border: 1.5px solid var(--line); background: transparent center/13px no-repeat;
  cursor: pointer; transition: background-color .15s, border-color .15s;
}
.checkrow input:checked {
  background-color: var(--accent); border-color: var(--accent);
  background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="13" height="13" viewBox="0 0 13 13" fill="none"><path d="M2.5 6.8L5.2 9.5L10.5 3.5" stroke="%230e0e11" stroke-width="2.2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
}

/* ---- etiket / pill ---- */
.pill { display: inline-block; font-family: var(--mono); font-size: 10px; letter-spacing: .08em; padding: 3px 8px; border-radius: 999px; border: 1px solid var(--line); color: var(--ink-soft); text-transform: uppercase; }
.pill.active { color: var(--accent); border-color: #44521f; background: #1c2010; }

/* ---- switch / aç-kapa satırı ----
   Tıklanabilir satır + sağda pist & topuz. Açık durum = .on (JS .on'u taşır; input gizli).
   Sayfaya özel sarmalayıcı (örn. index.html .prov-group) bu primitive'i kullanır. */
.switch-row { position: relative; display: flex; align-items: center; gap: var(--space-3); padding: var(--space-6) var(--space-4) var(--space-6) 32px; border-radius: var(--radius-lg); cursor: pointer; }
.switch-row input { position: absolute; opacity: 0; width: 0; height: 0; pointer-events: none; }
.switch-name { display: block; font-weight: 600; font-size: var(--fs-lg); color: var(--ink); }
.switch-desc { display: block; font-size: var(--fs-base); color: var(--ink-soft); margin-top: 2px; }
/* pist hep nötr; aç-durumunu yalnız topuz taşır (içi lime olmaz) */
.switch-track { flex: none; width: 40px; height: 22px; border-radius: var(--radius-pill); background: var(--line); border: 1px solid var(--line); position: relative; transition: border-color .18s ease; }
.switch-track::after { content: ""; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: var(--ink-faint); transition: transform .18s ease, background .18s ease; }
.switch-row.on .switch-track { border-color: var(--accent); }
.switch-row.on .switch-track::after { transform: translateX(18px); background: var(--accent); }

/* ---- chevron / küçük yön oku ----
   Akordeon/blok başlıklarında ortak ok ikonu. Açılınca döndürmeyi kapsayıcı yapar
   (örn. .acc.open .acc-bar .chev). */
.chev { color: var(--ink-faint); font-size: var(--fs-sm); transition: transform .15s; width: 14px; flex: none; }

/* ---- akordeon ----
   Kapalı başlar, .open ile açılır (JS .open'u taşır). Dashed kutu; başlık çubuğu (.acc-bar:
   .chev ok + .t başlık + .acc-hint sağ ipucu) + gövde (.acc-body). */
.acc { border: 1px dashed var(--line); border-radius: var(--radius-md); transition: border-color .15s ease; }
.acc:hover { border-color: var(--ink-faint); }
.acc-bar { display: flex; align-items: center; gap: var(--space-3); width: 100%; padding: 14px var(--space-4); background: transparent; border: 0; border-radius: var(--radius-md); cursor: pointer; text-align: left; color: var(--ink); }
.acc-bar:hover { background: var(--surface-2); }
.acc.open .acc-bar .chev { transform: rotate(90deg); }
.acc-bar .t { flex: 1; font-size: var(--fs-base); font-weight: 580; }
.acc-bar .acc-hint { font-size: var(--fs-sm); color: var(--ink-faint); flex: none; }
.acc.open .acc-bar { border-bottom: 1px dashed var(--line); border-radius: var(--radius-md) var(--radius-md) 0 0; }
.acc-body { display: none; padding: var(--space-4) var(--space-5) var(--space-5); }
.acc.open .acc-body { display: block; }
.acc-body > :first-child { margin-top: 0; }

/* ---- tablo ----
   Genel veri tablosu. Başlık (th) tıklanabilir/sıralı olabilir; .num = sağa hizalı sütun.
   Satır-tıklanabilir liste için tbody tr hover. Sütuna özel font/renk sayfada eklenir
   (örn. index.html .rtable .jira). */
.table { width: 100%; border-collapse: collapse; }
.table th {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-faint); font-weight: 500; text-align: left; padding: 10px 14px;
  border-bottom: 1px solid var(--line); cursor: pointer; user-select: none; white-space: nowrap;
  transition: color .12s;
}
.table th:hover { color: var(--ink-soft); }
.table th.num, .table td.num { text-align: right; }
.table td { padding: 15px 14px; border-bottom: 1px solid var(--line-soft); font-size: var(--fs-base); vertical-align: middle; }
.table tbody tr { cursor: pointer; transition: background .12s; }
.table tbody tr:hover td { background: var(--surface); }

/* ---- avatar ---- */
.avatar { width: 36px; height: 36px; border-radius: 50%; background: var(--surface-2); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; font-size: var(--fs-lg); flex-shrink: 0; overflow: hidden; }
.avatar img { width: 100%; height: 100%; object-fit: cover; }

/* ---- rozet (renkli durum etiketi; .pill'in dolu/renkli kardeşi) ---- */
.badge { font-family: var(--mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; padding: 3px 8px; border-radius: 6px; font-weight: 600; white-space: nowrap; }
.badge.green { background: #20300f; color: var(--accent); }
.badge.red { background: #2e1414; color: var(--danger); }
.badge.amber { background: #2e2410; color: var(--warn); }

/* ---- boş durum ----
   .empty = basit dashed kutu; .empty-rep = ikon + büyük başlık + CTA (bkz. empty-state-cta-convention) */
.empty { text-align: center; color: var(--ink-faint); font-size: var(--fs-base); padding: 40px 20px; border: 1px dashed var(--line); border-radius: var(--radius-md); }
.empty-rep { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 56px 24px; }
.empty-rep .empty-ico { width: 48px; height: 48px; color: var(--ink-faint); opacity: .7; margin-bottom: 6px; }
.empty-rep .empty-rep-t { font-size: var(--fs-xl); font-weight: 640; color: var(--ink); letter-spacing: -.01em; }
.empty-rep .empty-rep-s { font-size: 15px; color: var(--ink-faint); }
.empty-rep .empty-rep-acts { display: flex; gap: 10px; margin-top: 18px; flex-wrap: wrap; justify-content: center; }

/* ---- yükleme göstergesi ---- */
.spinner { display: inline-block; width: 14px; height: 14px; border: 2px solid currentColor; border-top-color: transparent; border-radius: 50%; opacity: .9; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.center-load { display: flex; align-items: center; justify-content: center; gap: 10px; min-height: 100vh; color: var(--ink-soft); font-size: var(--fs-base); }

/* ---- modal (ortalı overlay) ---- */
.modal-bg { position: fixed; inset: 0; background: rgba(0,0,0,.6); display: none; align-items: center; justify-content: center; padding: 20px; z-index: 40; }
.modal-bg.on { display: flex; }
.modal { background: var(--surface); border: 1px solid var(--line); border-radius: 16px; padding: 24px; width: 100%; max-width: 560px; max-height: 86vh; overflow: auto; }
.modal h3 { font-size: 18px; margin-bottom: 16px; }
.modal-acts { display: flex; gap: 10px; justify-content: flex-end; margin-top: 20px; }

/* ---- drawer (sağdan açılan rail; .modal-bg tabanını ezer) ---- */
.drawer-bg { align-items: stretch; justify-content: flex-end; padding: 0; }
.drawer {
  max-width: 470px; width: 100%; height: 100%; max-height: 100%;
  border-radius: 0; border: 0; border-left: 1px solid var(--line);
  padding: 0; overflow: hidden; display: flex; flex-direction: column;
}
.drawer-bg.on .drawer { animation: drawerIn .22s cubic-bezier(.22,.61,.36,1); }
@keyframes drawerIn { from { transform: translateX(100%); } to { transform: translateX(0); } }
.drawer-head { padding: 18px 24px 14px; border-bottom: 1px solid var(--line); flex-shrink: 0; }
.drawer-acts { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.drawer-acts .spring { flex: 1; }
.drawer h3 { margin-bottom: 0; }
.drawer-body { padding: 18px 24px 28px; overflow: auto; flex: 1; }
