/* ============ ERP v2 ek stiller ============ */

:root {
  --line: var(--border);
  --card: var(--surface);
}

/* ============ Faz 10 — Raporlama / BI / Yönetici Kokpiti ============ */
.report-kpi { cursor: pointer; transition: transform .12s ease, box-shadow .12s ease; }
.report-kpi:hover { transform: translateY(-2px); box-shadow: 0 6px 18px -8px rgba(0,0,0,.18); }
.report-kpi:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; border-radius: var(--r-lg); }
.report-masked { color: var(--muted); letter-spacing: .12em; font-weight: 700; }
.report-mini-bar { display: block; height: 7px; border-radius: 6px; background: var(--surface-hover); overflow: hidden; }
.report-mini-bar > span { display: block; height: 100%; border-radius: 6px; background: var(--primary); }
.report-bucket-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; }
.report-bucket { background: var(--surface-hover); border-radius: var(--r-md); padding: 10px 12px; }
.report-bucket .b-label { font-size: 11px; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; }
.report-bucket .b-value { font-size: 14px; font-weight: 800; font-variant-numeric: tabular-nums; margin-top: 3px; }
.report-cost-split { display: flex; flex-direction: column; gap: 8px; }
.report-cost-row { display: grid; grid-template-columns: 130px 1fr 110px; gap: 10px; align-items: center; font-size: 12.5px; }
.report-cost-row .c-amt { text-align: right; font-variant-numeric: tabular-nums; font-weight: 700; }
.report-note-banner { background: var(--amber-soft); color: var(--amber); border-radius: var(--r-md); padding: 9px 12px; font-size: 12px; font-weight: 600; display: flex; gap: 8px; align-items: center; margin-bottom: 12px; }

/* Açık tema kontrast güçlendirme */
[data-theme="light"] {
  --muted: #79808f;
  --faint: #a3a9b5;
  --border: #e3e6ea;
  --border-strong: #d1d5dd;
}

/* site chip */
.site-chip {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-ui); font-size: 12px; font-weight: 700; color: var(--text-2);
  background: var(--surface-2); border: 1px solid var(--border);
  padding: 3px 9px; border-radius: 20px; white-space: nowrap;
  transition: border-color 0.12s, color 0.12s;
}
.site-chip:hover { border-color: var(--primary); color: var(--primary-text); }

/* tabs */
.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); padding: 0 16px; overflow-x: auto; }
.tab {
  border: none; background: none; font-family: inherit; cursor: pointer;
  font-size: 13px; font-weight: 700; color: var(--muted);
  padding: 12px 13px 11px; border-bottom: 2px solid transparent; margin-bottom: -1px;
  white-space: nowrap; display: inline-flex; align-items: center; gap: 7px;
  transition: color 0.12s;
}
.tab:hover { color: var(--text); }
.tab.active { color: var(--primary-text); border-bottom-color: var(--primary); }
.tab-count {
  font-size: 10.5px; font-family: var(--font-mono); font-weight: 600;
  background: var(--surface-hover); color: var(--muted); border-radius: 12px; padding: 1px 7px;
}
.tab.active .tab-count { background: var(--primary-soft); color: var(--primary-text); }

/* stepper */
.stepper { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.step { display: flex; align-items: center; gap: 6px; }
.step-dot {
  width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0;
  display: grid; place-items: center;
  font-size: 10px; font-weight: 700; font-family: var(--font-mono);
  background: var(--surface-hover); color: var(--muted); border: 1px solid var(--border);
}
.step-label { font-size: 11.5px; font-weight: 600; color: var(--muted); white-space: nowrap; }
.step.done .step-dot { background: var(--green-soft); color: var(--green); border-color: transparent; }
.step.done .step-label { color: var(--text-2); }
.step.now .step-dot { background: var(--primary); color: #fff; border-color: var(--primary); }
.step.now .step-label { color: var(--primary-text); font-weight: 700; }
.step.dead .step-dot { background: var(--red-soft); color: var(--red); border-color: transparent; }
.step.dead .step-label { color: var(--red); }
.step-line { width: 18px; height: 1.5px; background: var(--border); flex-shrink: 0; }
.step-line.done { background: var(--green); opacity: 0.45; }

/* modal */
.modal {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-xl); box-shadow: var(--shadow-pop);
  display: flex; flex-direction: column; max-height: 86vh;
  animation: modalIn 0.2s var(--ease);
}
@keyframes modalIn { from { opacity: 0; transform: translateY(10px) scale(0.985); } }
.modal .drawer-body { overflow-y: auto; }

/* form hataları */
.field.has-err .input, .field.has-err .select { border-color: var(--red); background: color-mix(in srgb, var(--red) 4%, var(--surface)); }
.err-msg { display: inline-flex; align-items: center; gap: 5px; font-size: 11.5px; font-weight: 600; color: var(--red); }

/* filedrop */
.filedrop {
  display: flex; align-items: center; gap: 10px; width: 100%;
  font-family: inherit; font-size: 12.5px; font-weight: 600; color: var(--text-2);
  padding: 12px 14px; border-radius: var(--r-md); cursor: pointer;
  border: 1.5px dashed var(--border-strong); background: var(--surface-2);
  transition: border-color 0.12s, background 0.12s;
}
.filedrop:hover { border-color: var(--primary); background: var(--primary-soft); }
.filedrop.done { border-style: solid; border-color: color-mix(in srgb, var(--green) 35%, var(--border)); background: var(--green-soft); cursor: default; }
.filedrop:disabled { cursor: progress; }

/* empty state */
.empty { display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 44px 20px; text-align: center; }
.empty-ic {
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--surface-hover); color: var(--faint);
  display: grid; place-items: center; margin-bottom: 4px;
}
.empty-title { font-size: 14px; font-weight: 700; }
.empty-sub { font-size: 12.5px; color: var(--muted); max-width: 320px; }
.empty-state-action { margin-top: 8px; }
.empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; padding: 32px 18px; text-align: center; color: var(--muted);
}

/* UI-1 design system primitives */
.interactive-card {
  cursor: pointer;
  transition: border-color 0.14s var(--ease), box-shadow 0.14s var(--ease), transform 0.14s var(--ease), background 0.14s var(--ease);
}
.interactive-card:hover {
  border-color: color-mix(in srgb, var(--primary) 38%, var(--border));
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.interactive-card:focus-visible,
.shortcut-card:focus-visible,
.subnav-group button:focus-visible,
.empty-state-action:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--primary) 30%, transparent);
  outline-offset: 2px;
}
.shortcut-card { min-height: 82px; }
.shortcut-card-body { display: flex; align-items: center; gap: 12px; padding: 14px 16px; min-width: 0; }
.shortcut-icon {
  width: 38px; height: 38px; border-radius: 9px; flex-shrink: 0;
  display: grid; place-items: center; background: var(--primary-soft); color: var(--primary-text);
}
.shortcut-icon.green { background: var(--green-soft); color: var(--green); }
.shortcut-icon.amber { background: var(--amber-soft); color: var(--amber); }
.shortcut-icon.red { background: var(--red-soft); color: var(--red); }
.shortcut-content { flex: 1; min-width: 0; }
.shortcut-title { font-size: 13.5px; font-weight: 800; color: var(--text); }
.shortcut-desc, .shortcut-meta { font-size: 11.5px; color: var(--muted); line-height: 1.45; }
.shortcut-cta {
  font-size: 11px; color: var(--muted); font-weight: 800; white-space: nowrap;
}
.summary-card .card-pad { padding-top: 8px; }
.work-queue .card-pad { padding-top: 6px; }
.filter-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap;
  padding: 10px 0;
}
/* Toolbar: doğrudan Card içindeki filter-bar kenara yapışmasın, tablodan ince çizgiyle ayrılsın */
.card > .filter-bar {
  padding: 13px 16px;
  border-bottom: 1px solid var(--border);
}
.filter-bar-main, .filter-bar-right { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.filter-bar-right { color: var(--muted); }
.page-section { display: flex; flex-direction: column; gap: 12px; margin-bottom: 16px; }
.drawer-section {
  padding: 14px 0; border-top: 1px solid var(--border);
}
.drawer-section:first-child { border-top: none; padding-top: 0; }
.detail-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 14px;
}
.detail-grid > * { min-width: 0; }
.action-footer {
  display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap;
}
.action-footer.danger { justify-content: space-between; }
.status-pill {
  display: inline-flex; align-items: center; gap: 5px; border-radius: 999px;
  font-size: 11px; font-weight: 800; padding: 3px 8px;
  background: var(--surface-hover); color: var(--muted);
}
.status-pill.green { background: var(--green-soft); color: var(--green); }
.status-pill.amber { background: var(--amber-soft); color: var(--amber); }
.status-pill.red { background: var(--red-soft); color: var(--red); }
.status-pill.blue { background: var(--primary-soft); color: var(--primary-text); }
.subnav-group {
  display: flex; gap: 5px; overflow-x: auto; padding: 0 0 10px; margin-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.subnav-group button {
  border: 1px solid transparent; background: transparent; color: var(--muted);
  font-family: inherit; font-size: 12.5px; font-weight: 800; padding: 7px 10px;
  border-radius: var(--r-sm); cursor: pointer; white-space: nowrap;
}
.subnav-group button:hover { background: var(--surface-hover); color: var(--text); }
.subnav-group button.active, .subnav-group button[aria-selected="true"] {
  background: var(--primary-soft); color: var(--primary-text); border-color: color-mix(in srgb, var(--primary) 28%, var(--border));
}
.section-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 14px 16px 10px;
}
.section-header h3 { margin: 0; font-size: 14px; font-weight: 850; }
.section-header p { margin: 3px 0 0; font-size: 12px; color: var(--muted); }
.entity-header {
  display: flex; align-items: flex-start; gap: 12px; justify-content: space-between;
  border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--surface); padding: 16px;
}
.entity-header h2 { margin: 0; font-size: 18px; }
.entity-header p { margin: 4px 0 0; color: var(--muted); font-size: 12.5px; }
.entity-header-main { display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap; min-width: 0; flex: 1 1 auto; }
.entity-header-titles { min-width: 0; }
.entity-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.audit-trail { display: flex; flex-direction: column; gap: 8px; }

/* ---------- Global spacing / layout helpers ---------- */
.stack { display: flex; flex-direction: column; gap: 16px; }
.page-toolbar,
.panel-toolbar,
.section-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 14px;
}
.page-toolbar { margin-bottom: 16px; }
.panel-toolbar { padding: 14px 16px; border-bottom: 1px solid var(--border); }
.section-toolbar { margin: 4px 0 12px; }
.button-group {
  display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.inline-actions {
  display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.table-actions {
  display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap;
  justify-content: flex-end; margin-left: auto;
}
.table-wrap {
  width: 100%; max-width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch;
}
.badge,
.risk-badge {
  max-width: 100%;
}
.risk-badge {
  display: inline-flex; align-items: center; gap: 5px; border-radius: 999px;
  padding: 3px 8px; font-size: 11px; font-weight: 800; white-space: nowrap;
  background: var(--surface-hover); color: var(--muted);
}
.demo-mode-badge {
  display: inline-flex; align-items: center; gap: 7px; flex-wrap: wrap;
  max-width: 240px; padding: 5px 9px; border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--amber) 24%, var(--border));
  background: var(--amber-soft); color: var(--amber); font-size: 11px; font-weight: 850;
}
.demo-mode-badge small {
  color: var(--text-2); font-size: 10.5px; font-weight: 700; white-space: nowrap;
}
.amount-cell { text-align: right; white-space: nowrap; font-variant-numeric: tabular-nums; }
.truncate-cell { max-width: 220px; min-width: 0; }
.truncate-cell .strong,
.truncate-cell .cell-main,
.truncate-cell .muted {
  display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mini-table {
  width: 100%; min-width: 680px; border-collapse: collapse; font-size: 12.5px;
}
.mini-table th,
.mini-table td {
  padding: 9px 10px; border-bottom: 1px solid var(--border); vertical-align: middle;
}
.mini-table th {
  color: var(--muted); font-size: 11px; font-weight: 850; text-align: left; text-transform: uppercase; letter-spacing: 0;
  background: var(--surface-2);
}
.mini-table th.num { text-align: right; }
.mini-table td .status-pill-wrap { display: inline-flex; justify-content: center; min-width: 78px; }
.content-spacing { padding: 16px; }
.stack-gap-sm { gap: 8px; }
.stack-gap-md { gap: 12px; }
.stack-gap-lg { gap: 16px; }
/* KPI / özet kart gridi (Cari & Nakit, Vergi, Kapanış) */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 12px; }
.kpi-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.kpi-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.acct-main-subnav {
  padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--surface); margin-bottom: 6px;
}
.acct-main-subnav .pill-tabs { flex: 0 1 auto; }
.acct-cash-subnav {
  padding: 12px 14px; border: 1px solid var(--border); border-radius: var(--r-lg);
  background: var(--surface); margin-bottom: 2px;
}
.acct-cash-subnav .segmented-control { max-width: 100%; }
.acct-party-panel { overflow: hidden; }
.acct-party-toolbar {
  margin-bottom: 0; background: var(--surface-2); border-top: 1px solid var(--border);
}
.acct-party-toolbar .search { max-width: 320px !important; }
.open-items-section { margin-top: 2px; }
.open-items-section .section-header { padding-left: 0; padding-right: 0; }
.open-items-table-wrap { border: 1px solid var(--border); border-radius: 8px; overflow-x: auto; }
.open-items-table th:first-child { border-top-left-radius: 8px; }
.open-items-table th:last-child { border-top-right-radius: 8px; text-align: right; }
.open-items-table td:last-child { text-align: right; }

/* Muhasebe Cari & Nakit layout */
.acct-top-panel {
  margin: 0 24px 12px;
  padding: 11px 15px;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  background: var(--card);
}
.acct-top-panel .subnav-group {
  border-bottom: none;
  padding: 0;
  margin-bottom: 0;
}
.acct-top-panel .subnav-group button {
  font-size: 13px;
  padding: 8px 13px;
}
/* Alt sekmeler — ana navigasyondan ayrı, küçük ikincil ada */
.acct-subtabs-panel {
  margin: 0 24px 16px;
  display: flex;
}
.acct-subtabs-panel .pill-tabs {
  flex: 0 1 auto;
}
.acct-cash-content {
  padding: 0 24px 24px;
  box-sizing: border-box;
}
.acct-cash-mode-panel {
  margin: 0 24px 16px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: var(--card);
}
.acct-cash-mode-tabs {
  width: fit-content;
  max-width: 100%;
}
.acct-cash-kpi-grid {
  margin-top: 18px;
  margin-bottom: 20px;
  gap: 14px;
  padding: 0;
}
.acct-cash-kpi-grid .stat { min-height: 116px; }
.acct-party-panel {
  margin-top: 18px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--card);
  box-sizing: border-box;
  overflow: visible;
}
.acct-party-toolbar {
  margin-top: 14px;
  margin-bottom: 14px;
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  background: transparent;
  border: none;
}
.open-items-table {
  min-width: 760px;
  table-layout: fixed;
}
.open-items-table th,
.open-items-table td {
  padding: 10px 12px;
  vertical-align: middle;
}
.open-items-table .amount-cell {
  text-align: right;
  white-space: nowrap;
}
.open-items-table .truncate-cell {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 720px) {
  .acct-cash-content {
    padding: 0 14px 18px;
  }
  .acct-top-panel,
  .acct-subtabs-panel,
  .acct-cash-mode-panel {
    margin-left: 14px;
    margin-right: 14px;
  }
}

/* form grid — drawer/panel form alanları */
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.form-grid > label { display: flex; flex-direction: column; gap: 6px; font-size: 12px; font-weight: 700; color: var(--text-2); min-width: 0; }
.form-grid > label.full { grid-column: 1 / -1; }
.audit-row { border-left: 2px solid var(--border); padding-left: 10px; font-size: 12px; color: var(--text-2); }
.audit-row span { display: block; color: var(--muted); font-size: 11px; }
.audit-row p { margin: 2px 0 0; color: var(--muted); }

/* UI-3 drawer/detail standardi */
.drawer-header { display: flex; flex-direction: column; gap: 10px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.drawer-title-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.drawer-title-row h3 { margin: 0; font-size: 17px; font-weight: 850; letter-spacing: 0; }
.drawer-title-row p { margin: 4px 0 0; font-size: 12px; color: var(--muted); }
.drawer-status-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.drawer-header-actions { margin-left: auto; display: flex; gap: 8px; flex-wrap: wrap; }
.drawer-section-title { font-size: 11px; font-weight: 850; color: var(--muted); text-transform: uppercase; letter-spacing: 0; }
.drawer-summary-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.drawer-summary-item { border: 1px solid var(--border); border-radius: 8px; padding: 10px 11px; background: var(--surface-2); min-width: 0; }
.drawer-summary-item span, .drawer-meta-grid span { display: block; font-size: 10.5px; color: var(--muted); font-weight: 850; text-transform: uppercase; letter-spacing: 0; }
.drawer-summary-item b { display: block; margin-top: 4px; font-size: 14px; color: var(--text); overflow-wrap: anywhere; }
.drawer-summary-item small, .drawer-meta-grid small { display: block; margin-top: 3px; font-size: 11px; color: var(--muted); }
.drawer-meta-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px 14px; }
.drawer-meta-grid > div { min-width: 0; }
.drawer-meta-grid b { display: block; margin-top: 3px; font-size: 12.5px; color: var(--text-2); overflow-wrap: anywhere; }
.drawer-linked-list { display: grid; gap: 8px; }
.linked-record-btn {
  width: 100%; border: 1px solid var(--border); background: var(--surface); color: var(--text);
  border-radius: 8px; padding: 9px 10px; display: flex; align-items: center; gap: 8px; text-align: left;
  font-family: inherit; cursor: pointer;
}
.linked-record-btn:hover { border-color: var(--primary); background: var(--surface-hover); }
.linked-record-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.linked-record-btn span { font-size: 12.5px; font-weight: 800; flex: 1; min-width: 0; overflow-wrap: anywhere; }
.linked-record-btn small { color: var(--muted); font-size: 11px; margin-right: auto; }
.drawer-action-footer {
  position: sticky; bottom: -14px; display: flex; justify-content: flex-end; gap: 10px; flex-wrap: wrap;
  margin-top: 14px; padding: 14px 0 2px; background: linear-gradient(to top, var(--surface) 78%, transparent);
  border-top: 1px solid var(--border);
}
.drawer-danger-zone { border: 1px solid color-mix(in srgb, var(--red) 30%, var(--border)); background: var(--red-soft); border-radius: 8px; padding: 12px; display: flex; gap: 10px; justify-content: space-between; align-items: center; }
.drawer-danger-zone b { color: var(--red); font-size: 12.5px; }
.drawer-danger-zone p { margin: 3px 0 0; color: var(--muted); font-size: 11.5px; }
.drawer-danger-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.inline-fallback { display: flex; align-items: center; gap: 8px; border: 1px dashed var(--border); border-radius: 8px; padding: 9px 10px; background: var(--surface-2); color: var(--muted); font-size: 12px; }
@media (max-width: 720px) {
  .detail-grid { grid-template-columns: 1fr; }
  .section-header, .entity-header { flex-direction: column; align-items: stretch; }
  .action-footer { justify-content: stretch; }
  .action-footer .btn { flex: 1; justify-content: center; }
  .drawer-summary-grid, .drawer-meta-grid { grid-template-columns: 1fr; }
  .drawer-action-footer .btn, .drawer-danger-actions .btn { flex: 1 1 auto; justify-content: center; }
  .kpi-grid, .kpi-grid.cols-2, .kpi-grid.cols-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .kpi-grid, .kpi-grid.cols-2, .kpi-grid.cols-3 { grid-template-columns: 1fr; }
}

/* tablo footer */
.tbl-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; border-top: 1px solid var(--border);
}
.icon-btn:disabled { opacity: 0.35; cursor: default; }
.icon-btn:disabled:hover { background: none; }

/* komut paleti */
.palette {
  width: 600px; max-width: 92vw;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-xl); box-shadow: var(--shadow-pop);
  overflow: hidden; animation: modalIn 0.18s var(--ease);
}
.palette-input {
  display: flex; align-items: center; gap: 11px;
  padding: 15px 18px; border-bottom: 1px solid var(--border);
}
.palette-input input {
  flex: 1; border: none; background: none; outline: none;
  font-family: inherit; font-size: 15px; color: var(--text);
}
.palette-input kbd {
  font-family: var(--font-mono); font-size: 10.5px;
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: 5px; padding: 2px 7px; color: var(--muted);
}
.palette-body { max-height: 380px; overflow-y: auto; padding: 8px; }
.palette-group {
  font-size: 10.5px; font-weight: 700; color: var(--faint);
  text-transform: uppercase; letter-spacing: 0.06em; padding: 10px 10px 4px;
}
.palette-item {
  display: flex; align-items: center; gap: 11px; width: 100%;
  border: none; background: none; font-family: inherit; cursor: pointer;
  padding: 8px 10px; border-radius: var(--r-md);
}
.palette-item.active { background: var(--primary-soft); }
.palette-hint { padding: 28px 18px; text-align: center; }

/* onay kuyruğu satırı */
.appr-row {
  display: flex; align-items: center; gap: 12px;
  padding: 11px 14px; border: 1px solid var(--border); border-radius: var(--r-md);
  background: var(--surface-2);
}
.appr-row + .appr-row { margin-top: 8px; }
.li-icon,
.stat-icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 0;
}
.li-icon svg,
.stat-icon svg {
  display: block;
  flex-shrink: 0;
  margin: auto;
}

/* bildirim dropdown */
.notif-pop {
  position: absolute; top: calc(100% + 8px); right: 0;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--r-lg); box-shadow: var(--shadow-pop);
  width: 360px; max-width: 90vw; z-index: 60; overflow: hidden;
  animation: pop 0.14s var(--ease);
}
.notif-pop .body { max-height: 380px; overflow-y: auto; padding: 6px; }

/* detay sayfası başlık kartı */
.detail-hero {
  border-radius: var(--r-lg); border: 1px solid var(--border);
  background: var(--surface); box-shadow: var(--shadow-sm);
  padding: 20px 22px; margin-bottom: 16px;
  display: flex; gap: 18px; align-items: flex-start; flex-wrap: wrap;
}
.detail-mark {
  width: 48px; height: 48px; border-radius: 13px; flex-shrink: 0;
  display: grid; place-items: center; color: #fff;
}

/* timeline (audit) */
.tline { position: relative; padding-left: 22px; }
.tline::before { content: ""; position: absolute; left: 7px; top: 6px; bottom: 6px; width: 1.5px; background: var(--border); }
.tline-row { position: relative; padding: 8px 0; }
.tline-row::before {
  content: ""; position: absolute; left: -19.5px; top: 14px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--surface); border: 2px solid var(--border-strong);
}

/* puantaj grid */
.ts-grid { display: grid; grid-template-columns: repeat(30, 1fr); gap: 2px; }
.ts-cell {
  aspect-ratio: 1; border-radius: 3px; border: none; cursor: pointer; padding: 0;
  font-size: 8px; font-family: var(--font-mono); color: transparent;
  background: var(--surface-hover); transition: transform 0.08s;
}
.ts-cell:hover { transform: scale(1.25); }
.ts-cell.T { background: var(--green); opacity: 0.85; }
.ts-cell.Y { background: var(--amber); opacity: 0.8; }
.ts-cell.M { background: var(--primary); }
.ts-cell.X { background: var(--red); opacity: 0.55; }

/* checklist */
.chk-row {
  display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  border-radius: var(--r-sm); cursor: pointer; border: none; background: none;
  font-family: inherit; width: 100%; text-align: left;
}
.chk-row:hover { background: var(--surface-hover); }
.chk-box {
  width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0;
  border: 1.5px solid var(--border-strong); display: grid; place-items: center;
  color: #fff; transition: all 0.12s;
}
.chk-row.done .chk-box { background: var(--green); border-color: var(--green); }
.chk-label { font-size: 13px; font-weight: 600; color: var(--text-2); }
.chk-row.done .chk-label { color: var(--muted); text-decoration: line-through; }

/* Faz 9 - Yetki secimi: checklist stillerinden bagimsiz, okunabilir permission selector */
.permission-selector {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-bottom: 88px;
}
.permission-selector-toolbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.permission-selector-search { flex: 1 1 260px; min-width: 180px; }
.permission-selector-risk { flex: 0 0 150px; }
.permission-selector-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}
.permission-group {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  overflow: visible;
}
.permission-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  background: var(--surface-hover);
  border-bottom: 1px solid var(--border);
}
.permission-group-title {
  display: flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
}
.permission-group-title b {
  font-size: 12.5px;
  color: var(--text);
}
.permission-group-title span {
  font-size: 11px;
  color: var(--muted);
  white-space: nowrap;
}
.permission-group-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.permission-group-body {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px;
  height: auto;
  max-height: none;
  overflow: visible;
}
.permission-option {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--surface);
  color: var(--text);
  min-height: 56px;
  cursor: pointer;
}
.permission-option:hover {
  background: var(--surface-2);
  border-color: var(--border-strong);
}
.permission-option.selected {
  background: color-mix(in srgb, var(--primary) 6%, var(--surface));
  border-color: color-mix(in srgb, var(--primary) 34%, var(--border));
}
.permission-option input {
  width: 18px;
  height: 18px;
  margin: 1px 0 0;
  accent-color: var(--primary);
}
.permission-option-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.permission-option-title {
  font-size: 13px;
  font-weight: 750;
  color: var(--text);
  line-height: 1.3;
}
.permission-option-desc {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.permission-option-key {
  font-size: 11px;
  color: var(--muted);
  background: transparent;
  font-family: var(--font-mono);
  overflow-wrap: anywhere;
}
.permission-risk-badge {
  white-space: nowrap;
  align-self: start;
}

/* projeksiyon barları */
.proj-seg { display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 130px; }
.proj-bal { font-size: 19px; font-weight: 800; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }

/* buton ek durumları */
.btn:disabled { opacity: 0.45; cursor: default; pointer-events: none; }
.btn.btn-danger { background: var(--red); border-color: var(--red); color: #fff; }
.btn.btn-danger:hover { background: color-mix(in srgb, var(--red) 88%, black); }
.btn .spin { animation: spin 0.8s linear infinite; display: inline-flex; }
@keyframes spin { to { transform: rotate(360deg); } }

/* rol kapsam bandı */
.scope-band {
  display: flex; align-items: center; gap: 9px;
  font-size: 12px; font-weight: 600; color: var(--amber);
  background: var(--amber-soft); border: 1px solid color-mix(in srgb, var(--amber) 25%, transparent);
  padding: 8px 13px; border-radius: var(--r-md); margin-bottom: 14px;
}

/* muhasebe ana paneli / iş kuyruğu */
.queue-row { transition: background 0.12s, border-color 0.12s; }
/* Faz 21 — Gönderim kuyruğu özeti + grup başlıkları */
.queue-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1px; background: var(--border); border: 1px solid var(--border);
  border-radius: var(--r-lg, 12px); overflow: hidden; margin-bottom: 14px;
}
.queue-summary-item { display: flex; flex-direction: column; gap: 4px; padding: 12px 16px; background: var(--surface); }
.queue-summary-item .qs-label { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.queue-summary-item .qs-value { font-size: 20px; font-weight: 800; color: var(--text); letter-spacing: -0.02em; }
.queue-group-title { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 750; color: var(--text); }
.queue-group + .queue-group { margin-top: 14px; }
.queue-group-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.queue-group-head .queue-group-title svg { color: var(--muted); }
.queue-group-count {
  display: inline-flex; align-items: center; justify-content: center; min-width: 22px; height: 20px;
  padding: 0 7px; border-radius: 999px; background: var(--surface-hover); color: var(--text-2);
  font-size: 11.5px; font-weight: 800;
}
.queue-more {
  margin-top: 6px; width: 100%; text-align: left; padding: 7px 10px; border: 1px dashed var(--border);
  border-radius: var(--r-md, 8px); background: none; color: var(--muted); font-family: inherit;
  font-size: 12px; font-weight: 700; cursor: pointer; transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.queue-more:hover { background: var(--surface-hover); color: var(--text); border-color: var(--border-strong); }
/* İş kuyruğu içeriği panel kenarına yapışmasın — yatay + alt iç boşluk */
.work-queue > .queue-list,
.work-queue > .queue-group { padding-left: 16px; padding-right: 16px; }
.work-queue > .queue-list:last-child,
.work-queue > .queue-group:last-child { padding-bottom: 16px; }
.queue-row:hover { background: var(--surface); border-color: var(--border-strong); }
.queue-row .btn.ghost { padding: 6px 8px; }
.queue-row .badge { flex-shrink: 0; white-space: nowrap; }
.queue-row .li-icon { flex-shrink: 0; }

/* drawer aksiyon grubu */
.drawer-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.drawer-actions .btn { flex: 1 1 auto; min-width: 120px; }

/* mobil iyileştirme */
@media (max-width: 720px) {
  .detail-hero { padding: 16px; }
  .stepper { gap: 4px; }
  .step-label { display: none; }
  .step.now .step-label { display: inline; }
  .tabs { padding: 0 8px; }
  .drawer { width: 100vw !important; max-width: 100vw; }
  .toasts { left: 12px; right: 12px; bottom: 12px; }
  .toast { min-width: 0; }
}

/* Faz 3B-2/3B-7 — tıklanabilir muhasebe kısayol kartları */
.acct-shortcut { transition: box-shadow 0.15s ease, transform 0.15s ease, border-color 0.15s ease; }
.acct-shortcut:hover { box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08); transform: translateY(-2px); border-color: var(--primary); }
.acct-shortcut:focus-visible { outline: 2px solid var(--primary); outline-offset: 2px; }
.acct-shortcut .acct-shortcut-cta { opacity: 0.55; transition: opacity 0.15s ease; }
.acct-shortcut:hover .acct-shortcut-cta,
.acct-shortcut:focus-visible .acct-shortcut-cta { opacity: 1; color: var(--primary); }

/* UI-2 muhasebe bilgi mimarisi */
.acct-shell { display: flex; flex-direction: column; gap: 12px; min-width: 0; padding-top: 6px; }
.acct-group-nav { margin-bottom: 0; }
.acct-subnav {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 10px 0 12px; border-bottom: 1px solid var(--border);
}
.acct-subnav .pill-tabs { flex: 1 1 auto; }
.acct-main { min-width: 0; }
.acct-panel-grid { align-items: start; }
.acct-home-grid { align-items: stretch; }

/* UI-4 operasyon ekranları: ortak aksiyon/segment standardı */
.toolbar-actions,
.action-row {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.segmented-control,
.pill-tabs {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface-2);
  overflow-x: auto;
  max-width: 100%;
}
.segmented-control-item,
.pill-tab {
  border: 0;
  background: transparent;
  color: var(--text-2);
  border-radius: var(--r-sm);
  padding: 7px 10px;
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}
.segmented-control-item:hover,
.pill-tab:hover { background: var(--surface-hover); color: var(--text); }
.segmented-control-item.active,
.pill-tab.active {
  background: var(--surface);
  color: var(--primary-text);
  box-shadow: var(--shadow-xs);
}
.primary-action { background: var(--primary); border-color: var(--primary); color: #fff; }
.secondary-action { background: var(--surface); border-color: var(--border); color: var(--text); }
.subtle-action { background: transparent; border-color: transparent; color: var(--text-2); }
.ops-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.ops-summary-grid { margin-bottom: 16px; }
.ops-work-queue { display: grid; gap: 10px; }
.ops-card-grid,
.ops-quick-actions {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}
.ops-card,
.ops-quick-action {
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: var(--r-md);
  padding: 12px;
  min-width: 0;
}
button.ops-card,
button.ops-quick-action {
  font-family: inherit;
  cursor: pointer;
  text-align: left;
}
button.ops-card:hover,
button.ops-quick-action:hover { border-color: var(--primary); box-shadow: var(--shadow-sm); }
button.ops-card:focus-visible,
button.ops-quick-action:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.ops-card-header,
.ops-status-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.ops-card-actions { display: flex; justify-content: flex-end; gap: 8px; flex-wrap: wrap; }
.ops-empty-state {
  border: 1px dashed var(--border);
  border-radius: var(--r-md);
  padding: 14px;
  color: var(--muted);
  background: var(--surface-2);
}

.primary-action:hover { background: var(--primary-hover); border-color: var(--primary-hover); }
.secondary-action:hover { background: var(--surface-hover); border-color: var(--border-strong); }
.subtle-action:hover { background: var(--surface-hover); color: var(--text); }

/* UI-5 — focus-visible + accessibility */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.btn:focus-visible,
.icon-btn:focus-visible,
.segmented-control-item:focus-visible,
.pill-tab:focus-visible,
.subnav-group button:focus-visible,
.tabs .tab:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--primary) 35%, transparent);
  outline-offset: 2px;
}
.segmented-control-item.active:focus-visible,
.pill-tab.active:focus-visible,
.subnav-group button.active:focus-visible,
.tabs .tab.active:focus-visible {
  outline-color: var(--primary);
}
.btn.btn-danger:focus-visible {
  outline-color: color-mix(in srgb, var(--red) 40%, transparent);
}
.stat-clickable:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: var(--r-md);
}

/* UI-5 — action row / toolbar responsive standardı */
.action-row,
.toolbar-actions { min-width: 0; }
.toolbar-actions .btn,
.action-row .btn { min-width: 0; }

@media (max-width: 920px) {
  .acct-subnav { margin-left: -2px; padding-bottom: 10px; }
  .acct-home-grid, .acct-panel-grid { grid-template-columns: 1fr !important; }
  .ops-filter-bar { align-items: stretch; }
  .toolbar-actions { justify-content: flex-start; }
  .segmented-control,
  .pill-tabs { max-width: 100%; }
}

@media (max-width: 720px) {
  .toolbar-actions,
  .action-row { flex-direction: column; align-items: stretch; }
  .toolbar-actions .btn,
  .action-row .btn { width: 100%; justify-content: center; }
  .drawer-action-footer { flex-direction: column; align-items: stretch; }
}

/* ============ Faz 20 — In-App Feedback ============ */
.feedback-fab {
  position: fixed; right: 18px; bottom: 18px; z-index: 80;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px; border: none; border-radius: 999px; cursor: pointer;
  background: var(--primary); color: #fff; font-weight: 700; font-size: 13px;
  box-shadow: 0 6px 20px color-mix(in srgb, var(--primary) 40%, transparent);
  transition: transform .12s ease, background .12s ease;
}
.feedback-fab:hover { background: var(--primary-hover); transform: translateY(-1px); }
.feedback-fab svg { flex-shrink: 0; }
.feedback-note {
  font-size: 12px; line-height: 1.5; color: var(--text-2);
  background: var(--surface-hover); border: 1px solid var(--border);
  border-radius: var(--r-md); padding: 9px 11px; margin-bottom: 12px;
}
.feedback-warn {
  display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600;
  color: var(--red); background: var(--red-soft); border-radius: var(--r-sm);
  padding: 7px 10px; margin: 2px 0 10px;
}
.feedback-check {
  display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--text-2);
  margin: 4px 0 12px; cursor: pointer;
}
.feedback-check input { width: 15px; height: 15px; }
.feedback-status { font-size: 12px; color: var(--text-2); border-top: 1px solid var(--border); padding-top: 10px; }
@media (max-width: 640px) {
  .feedback-fab { right: 12px; bottom: 12px; padding: 10px; }
  .feedback-fab span { display: none; }
}

/* Cari detayı — açık kalemler birleşik döküm bölümü */
.cari-openitems { margin-top: 6px; padding-top: 14px; border-top: 1px solid var(--border); }
.cari-openitems .section-header { margin-bottom: 10px; }
