* { box-sizing: border-box; }
body { margin: 0; font-family: var(--font); background: var(--bg); color: var(--fg); }
button { font: inherit; cursor: pointer; border-radius: var(--radius); border: 1px solid var(--border); background: var(--surface); color: var(--fg); padding: 8px 12px; }
button.primary { background: var(--primary); color: #fff; border-color: var(--primary); }
button.danger { color: var(--danger); border-color: var(--danger); }
button:hover { filter: brightness(0.97); }
input { font: inherit; padding: 9px 11px; border-radius: var(--radius); border: 1px solid var(--border); background: var(--surface); color: var(--fg); width: 100%; }
select { font: inherit; padding: 6px 28px 6px 10px; border-radius: var(--radius); border: 1px solid var(--border); background: var(--surface); color: var(--fg); width: 100%; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; cursor: pointer; }

/* Login */
.login-wrap { min-height: 100vh; display: grid; place-items: center; }
.login-card { background: var(--surface); border: 1px solid var(--border); border-radius: 14px; padding: 28px; width: 340px; box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.login-card h1 { margin: 0 0 4px; font-size: 22px; }
.login-card p { margin: 0 0 20px; color: var(--muted); font-size: 13px; }
.field { margin-bottom: 14px; }
.field label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 6px; }
.err { color: var(--danger); font-size: 13px; min-height: 18px; margin-bottom: 8px; }

/* App shell */
.topbar { display: flex; align-items: center; gap: 12px; padding: 10px 16px; background: var(--surface); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: var(--z-nav); }
.topbar .brand { font-weight: 700; }
.topbar .spacer { flex: 1; }
.topbar .user { color: var(--muted); font-size: 13px; }

.toolbar { display: flex; gap: 8px; align-items: center; padding: 10px 16px; flex-wrap: wrap; }
/* Buton içi ikon + metin dikey ortalı (ui-icon ile hizalı) */
.toolbar button, .subbar button, .nav button, .nav .brand, .app-foot .sb-ic { display: inline-flex; align-items: center; gap: 6px; line-height: 1; }
.crumbs { display: flex; gap: 4px; align-items: center; padding: 6px 16px; color: var(--muted); font-size: 14px; flex-wrap: wrap; }
.crumbs a { color: var(--primary); cursor: pointer; text-decoration: none; }
.crumbs .sep { opacity: .5; }

.list { margin: 8px 16px; border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); background: var(--bg-surface, var(--surface)); overflow: hidden; position: relative; }
/* Izgarada fare ile kutu (marquee) seçimi */
.vm-btn { display: inline-flex; align-items: center; gap: 6px; }
.vm-btn .vm-lbl { margin-left: 2px; }
.filter-wrap { position: relative; display: inline-flex; align-items: center; }
.filter-wrap > ui-icon { position: absolute; left: 9px; color: var(--muted); pointer-events: none; }
.filter-wrap .filter-input { padding-left: 30px; }
.crumbs a.crumb-root { display: inline-flex; align-items: center; gap: 5px; }
.marquee { position: absolute; border: 1px solid var(--color-primary, var(--primary)); background: color-mix(in srgb, var(--color-primary, var(--primary)) 14%, transparent); border-radius: 3px; z-index: 5; pointer-events: none; }
/* Başlık ve satırlar AYNI grid'i paylaşır → sütunlar tam hizalı */
.row { display: grid; grid-template-columns: 40px minmax(140px, 1fr) 84px 90px 150px 150px 96px; gap: 10px; align-items: center; padding: 9px 12px; border-bottom: 1px solid var(--border); }
/* P1b: seçim kutusu sütunu varsayılan GİZLİ (toolbar'daki ☐ toggle açar) — fare/ok/Shift seçimi her zaman çalışır */
.list.no-sel .sel-col { display: none; }
.list.no-sel .row { grid-template-columns: minmax(140px, 1fr) 84px 90px 150px 150px 96px; }
/* P1b: arama eşleşme vurgusu — ad içinde renkli blok */
mark.hl { background: var(--primary); color: #fff; border-radius: 3px; padding: 0 2px; }
.row:last-child { border-bottom: none; }
/* P2: liste başlığı UI kit (ui-table__head) görünümünde — sticky, DS token'lar */
.row.head { position: sticky; top: 0; z-index: 2; background: var(--bg-sunken, var(--surface)); color: var(--text-muted, var(--muted)); font-size: var(--text-xs, 11px); font-weight: var(--font-semibold, 600); text-transform: uppercase; letter-spacing: .05em; border-bottom: 1px solid var(--border-default, var(--border)); }
.row.item:hover { background: var(--bg-hover, color-mix(in srgb, var(--primary) 7%, transparent)); }
.row.item.sel { background: var(--color-primary-soft, color-mix(in srgb, var(--primary) 14%, transparent)); }
.row .sel-col { display: flex; align-items: center; justify-content: center; }
.row .sel-col input { width: 16px; height: 16px; cursor: pointer; margin: 0; }
.row .name { display: flex; align-items: center; gap: 8px; min-width: 0; cursor: pointer; }
.row .name .ic { flex: 0 0 22px; display: inline-flex; align-items: center; justify-content: center; }
.row .name .nm { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.row .meta { color: var(--muted); font-size: 13px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.row .meta.size, .row .meta.date { text-align: right; }
.row .meta.type { text-align: left; }
.row .actions { display: flex; gap: 6px; justify-content: flex-end; align-items: center; }
.row .actions button { padding: 3px 8px; font-size: 13px; line-height: 1; }
/* Orta genişlik: oluşturma tarihini gizle */
@media (max-width: 1100px) {
  .row { grid-template-columns: 40px minmax(140px, 1fr) 84px 90px 150px 96px; }
  .list.no-sel .row { grid-template-columns: minmax(140px, 1fr) 84px 90px 150px 96px; }
  .row .meta.cdate { display: none; }
}
/* Dar ekran: tür/boyut/tarihleri gizle (checkbox · ad · işlemler kalır) */
@media (max-width: 720px) {
  .row { grid-template-columns: 36px minmax(0, 1fr) 96px; }
  .list.no-sel .row { grid-template-columns: minmax(0, 1fr) 96px; }
  .row .meta.size, .row .meta.date, .row .meta.type, .row .meta.cdate { display: none; }
}

.empty { text-align: center; color: var(--muted); padding: 40px; }
/* Merkezi bildirim — en üst katman (--z-toast), modal/menü dahil her şeyin üstünde */
.toast-stack { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); display: flex; flex-direction: column; gap: 8px; align-items: center; z-index: var(--z-toast); pointer-events: none; }
.toast { position: relative; display: flex; align-items: center; gap: 8px; padding: 10px 16px; border-radius: 8px; font-size: 14px; max-width: 90vw; opacity: 0; transform: translateY(8px); transition: opacity .2s, transform .2s; box-shadow: 0 6px 22px rgba(0,0,0,.28); pointer-events: auto; }
.toast.show { opacity: .97; transform: none; }
.toast .toast-ic { font-weight: 700; }
.toast-info { background: var(--fg); color: var(--bg); }
.toast-success { background: var(--success); color: #fff; }
.toast-error { background: var(--danger); color: #fff; }
.toast-warning { background: #d97706; color: #fff; }

/* ---- Phase 1B: upload progress, dropzone, modal, context menu, preview ---- */
.upload-progress { width: 180px; height: 8px; background: var(--border); border-radius: 999px; overflow: hidden; }
.upload-progress .bar { height: 100%; width: 0; background: var(--primary); transition: width .15s; }
.list.dragover { outline: 2px dashed var(--primary); outline-offset: -4px; background: color-mix(in srgb, var(--primary) 6%, transparent); }
.row .actions button { padding: 3px 8px; font-size: 13px; line-height: 1; }

/* Context menu */
.context-menu { position: fixed; z-index: var(--z-menu); min-width: 200px; background: var(--surface); border: 1px solid var(--border); border-radius: 10px; padding: 6px; box-shadow: 0 12px 30px rgba(0,0,0,.2); }
.context-item { display: flex; align-items: center; gap: 10px; width: 100%; text-align: left; border: none; background: transparent; padding: 8px 10px; border-radius: 7px; font-size: 14px; }
.context-item:hover { background: color-mix(in srgb, var(--primary) 12%, transparent); }
.context-item.danger { color: var(--danger); }
.context-item:disabled { opacity: .5; cursor: default; }
.context-item .ci-icon { width: 18px; text-align: center; }
.context-sep { height: 1px; background: var(--border); margin: 5px 4px; }

/* Preview */
.pv-img { max-width: 100%; max-height: 70vh; display: block; margin: 0 auto; }
.pv-media { max-width: 100%; max-height: 70vh; display: block; margin: 0 auto; }
.pv-frame { width: 100%; height: 70vh; border: none; background: #fff; }
.pv-text { white-space: pre-wrap; word-break: break-word; max-height: 70vh; overflow: auto; background: var(--bg); padding: 12px; border-radius: 8px; font-family: ui-monospace, monospace; font-size: 13px; margin: 0; }

/* ---- Phase 2: nav + backup view ---- */
.nav { display: flex; align-items: center; gap: 14px; padding: 10px 16px; background: var(--surface); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: var(--z-nav); }
.nav .brand { font-weight: 700; }
.nav .spacer { flex: 1; }
.nav .user { color: var(--muted); font-size: 13px; }
.tabs { display: flex; gap: 6px; }
.navbtn { background: transparent; border: 1px solid transparent; padding: 7px 14px; border-radius: 8px; color: var(--muted); }
.navbtn:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.navbtn.active { background: color-mix(in srgb, var(--primary) 14%, transparent); color: var(--primary); border-color: color-mix(in srgb, var(--primary) 30%, transparent); font-weight: 600; }

.bk-row { display: grid; grid-template-columns: minmax(120px,1.2fr) 110px minmax(160px,2fr) auto; gap: 12px; align-items: center; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.bk-row:last-child { border-bottom: none; }
.bk-head { background: var(--surface); color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.bk-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bk-path { color: var(--muted); font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bk-actions { display: flex; gap: 6px; justify-content: flex-end; flex-wrap: wrap; }
.bk-actions button { padding: 4px 10px; font-size: 13px; }

.badge { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 12px; background: color-mix(in srgb, var(--muted) 18%, transparent); color: var(--fg); }
.badge.ok { background: color-mix(in srgb, var(--success) 22%, transparent); color: var(--success); }
.badge.warn { background: color-mix(in srgb, #d97706 24%, transparent); color: #b45309; }
.badge.danger { background: color-mix(in srgb, var(--danger) 20%, transparent); color: var(--danger); }

.bk-form .field { margin-bottom: 12px; }
.bk-form label { display: block; font-size: 12px; color: var(--muted); margin-bottom: 5px; }
.bk-form select { font: inherit; width: 100%; padding: 9px 28px 9px 11px; border-radius: var(--radius); border: 1px solid var(--border); background-color: var(--surface); color: var(--fg); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.bk-summary { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.bk-summary .badge { font-size: 13px; }
details { margin: 8px 0; }
summary { cursor: pointer; color: var(--primary); font-size: 14px; }
.bk-hist { width: 100%; border-collapse: collapse; font-size: 14px; }
.bk-hist th, .bk-hist td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.bk-hist th { color: var(--muted); font-size: 12px; text-transform: uppercase; }
@media (max-width: 720px) { .bk-row { grid-template-columns: 1fr auto; } .bk-row > span:nth-child(2), .bk-path { display: none; } .grid2 { grid-template-columns: 1fr; } }

/* ---- Phase 2C: select stili + Windows tarzı gezinme ikonları ---- */
.toolbar select {
  font: inherit; padding: 8px 32px 8px 11px; border-radius: var(--radius);
  border: 1px solid var(--border); background-color: var(--surface); color: var(--fg);
  cursor: pointer; appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat; background-position: right 10px center;
}
.toolbar select:hover { border-color: var(--primary); }
.toolbar select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent); }

.navicons { display: inline-flex; gap: 3px; margin-right: 8px; }
.navicon {
  width: 30px; height: 28px; padding: 0; display: inline-flex; align-items: center; justify-content: center;
  font-size: 17px; line-height: 1; border: 1px solid var(--border); background: var(--surface);
  border-radius: 7px; color: var(--fg);
}
.navicon:hover:not(:disabled) { background: color-mix(in srgb, var(--primary) 10%, transparent); border-color: var(--primary); color: var(--primary); }
.navicon:disabled { opacity: .38; cursor: default; }

/* ---- Phase 3: sync conflict satırları ---- */
.cf-row { padding: 12px; border: 1px solid var(--border); border-radius: 10px; margin-bottom: 10px; }
.cf-path { font-weight: 600; margin-bottom: 4px; word-break: break-all; }
.cf-meta { color: var(--muted); font-size: 13px; margin-bottom: 10px; }
.cf-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.cf-actions button { padding: 5px 12px; font-size: 13px; }

/* ---- Phase 5: ızgara görünümleri (küçük/orta/büyük ikon) ---- */
.list.grid { display: grid; gap: 10px; padding: 14px 16px; align-content: start; align-items: start; }
.grid-small  { grid-template-columns: repeat(auto-fill, minmax(92px, 1fr)); }
.grid-medium { grid-template-columns: repeat(auto-fill, minmax(132px, 1fr)); }
.grid-large  { grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); }
.grid-xlarge { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); }
.tile { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 10px; border: 1px solid transparent; border-radius: 10px; cursor: pointer; user-select: none; }
.tile:hover { background: color-mix(in srgb, var(--primary) 7%, transparent); }
.tile.sel { background: color-mix(in srgb, var(--primary) 16%, transparent); border-color: color-mix(in srgb, var(--primary) 40%, transparent); }
.tile .thumb { width: 100%; display: flex; align-items: center; justify-content: center; overflow: hidden; border-radius: 8px; background: var(--bg); }
.grid-small  .thumb { height: 58px; }
.grid-medium .thumb { height: 96px; }
.grid-large  .thumb { height: 140px; }
.grid-xlarge .thumb { height: 200px; }
/* İçeriği KIRPMADAN tam göster (kutuyu doldurur, aspect korunur, ortalanır) */
.tile .thumb img { width: 100%; height: 100%; object-fit: contain; display: block; }
.tile .thumb ui-file-icon { display: flex; align-items: center; justify-content: center; }
.grid-small  .ic-lg { font-size: 36px; }
.grid-medium .ic-lg { font-size: 54px; }
.grid-large  .ic-lg { font-size: 76px; }
.tile .tname { font-size: 13px; text-align: center; width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; line-height: 1.3; }
.grid-large .tname { font-size: 14px; }
.grid-xlarge .tname { font-size: 15px; }
.grid-xlarge .ic-lg { font-size: 110px; }

/* ---- Phase 5B: subbar, sıralama, favori, detay paneli, loading ---- */
.subbar { display: flex; gap: 8px; align-items: center; padding: 0 16px 4px; flex-wrap: wrap; }
.subbar .filter-input { width: 240px; }
.subbar select, .subbar #sortDir, .subbar #favToggle { padding: 7px 10px; border: 1px solid var(--border); border-radius: var(--radius); background-color: var(--surface); color: var(--fg); font: inherit; }
.subbar select, .subbar #sortDir { padding: 7px 28px 7px 10px; }
.subbar #favToggle.active { color: #d97706; border-color: #d97706; }
.toolbar #detailToggle.active { color: var(--primary); border-color: var(--primary); }

.row.head .sortable { cursor: pointer; user-select: none; }
.row.head .sortable:hover { color: var(--primary); }
.fav-star { color: #d97706; margin-left: 4px; font-size: 12px; }
.tile { position: relative; }
.tile-fav { position: absolute; top: 6px; right: 8px; color: #d97706; font-size: 14px; text-shadow: 0 1px 2px rgba(0,0,0,.3); }

/* Yenile dönen ikon + liste loading */
@keyframes spin { to { transform: rotate(360deg); } }
#reload.spinning .ricon { display: inline-block; animation: spin .7s linear infinite; }
.list.loading { opacity: .55; transition: opacity .1s; }

/* Workspace + detay paneli (sağ / alt) — alanlar footer'a kadar uzar, içerik kendi içinde kayar */
.workspace { display: flex; flex: 1 1 auto; min-height: 0; }
.workspace .list { flex: 1 1 auto; min-width: 0; overflow: auto; }
.workspace.detail-right { flex-direction: row; }
/* P2: detay paneli ui-card görünümünde */
.detail { background: var(--bg-surface, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); margin: 8px 16px 8px 0; padding: 16px; overflow: auto; }
.workspace.detail-right .detail { flex: 0 0 340px; }
.detail-empty { color: var(--muted); text-align: center; padding: 24px 8px; }
.detail-thumb { height: 140px; display: flex; align-items: center; justify-content: center; background: var(--bg); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
.detail-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.detail-name { font-weight: 600; word-break: break-all; margin-bottom: 12px; }
.detail-list { display: grid; grid-template-columns: auto 1fr; gap: 6px 12px; margin: 0; font-size: 13px; }
.detail-list dt { color: var(--muted); }
.detail-list dd { margin: 0; word-break: break-all; }
.detail-list .mono { font-family: ui-monospace, monospace; font-size: 12px; }
.detail-list .hash { font-size: 11px; opacity: .85; }
@media (max-width: 720px) { .workspace.detail-right { flex-direction: column; } .workspace.detail-right .detail { flex: none; position: static; margin: 0 16px 12px; } }

/* ---- Phase 5: toplu yeniden adlandırma dialog ---- */
.rn-scope { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 12px; color: var(--muted); font-size: 14px; }
.rn-scope select { padding: 6px 28px 6px 8px; border: 1px solid var(--border); border-radius: 7px; background-color: var(--surface); color: var(--fg); }
.rn-inline { display: inline-flex; align-items: center; gap: 6px; color: var(--fg); white-space: nowrap; }
.rn-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.rn-sec { display: flex; flex-direction: column; gap: 4px; border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; }
.rn-sec-head { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 4px; }
.rn-toggle { display: inline-flex; align-items: center; gap: 7px; cursor: pointer; }
.rn-toggle input[type="checkbox"], .rn-chk input[type="checkbox"] { flex-shrink: 0; width: 14px; height: 14px; cursor: pointer; }
.rn-chk { display: flex; align-items: center; gap: 7px; font-size: 13px; padding: 1px 0; cursor: pointer; color: var(--fg); }
.rn-opts { display: flex; gap: 14px; flex-wrap: wrap; border-top: 1px solid var(--border); padding-top: 7px; margin-top: 2px; }
.rn-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; font-size: 13px; color: var(--muted); }
.rn-row > label { color: var(--muted); font-size: 12px; white-space: nowrap; }
.rn-row input, .rn-row select { font: inherit; font-size: 13px; padding: 4px 7px; border: 1px solid var(--border); border-radius: 6px; background-color: var(--surface); color: var(--fg); }
.rn-row select { padding-right: 28px; }
.rn-row input { width: 110px; } .rn-row input.sm { width: 90px; } .rn-row input.xs { width: 52px; }
.rn-preview { margin-top: 14px; border-top: 1px solid var(--border); padding-top: 10px; }
.rn-sum { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 8px; }
.rn-table { max-height: 240px; overflow: auto; border: 1px solid var(--border); border-radius: 8px; }
.rn-trow { display: grid; grid-template-columns: 1fr 24px 1fr; gap: 8px; align-items: center; padding: 6px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.rn-trow:last-child { border-bottom: none; }
.rn-trow.conflict { background: color-mix(in srgb, var(--danger) 10%, transparent); }
.rn-old { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rn-new { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rn-arrow { text-align: center; color: var(--muted); }
.rn-cf { color: var(--danger); font-weight: 400; font-size: 12px; }
.rn-empty { padding: 16px; text-align: center; color: var(--muted); }
@media (max-width: 720px) { .rn-grid { grid-template-columns: 1fr; } }

/* ---- Toplu Yeniden Adlandır — SAYFA modu (modalsız, içerik alanını doldurur) ---- */
/* Dosya listesiyle aynı desen: gri canvas (--bg-page) üzerinde beyaz dolgulu kartlar. */
.rn-page { display: flex; flex-direction: column; height: 100%; min-height: 0; background: var(--bg-page, var(--bg, var(--surface))); }
/* başlık çubuğu artık ortak .cv-head (yukarıda) — geri-oku + ikon + başlık + aksiyonlar */
.rn-page__body { flex: 1; min-height: 0; overflow: auto; padding: 16px 18px; }

/* Kapsam (sekme + kök/dizin ağacı) ve önizleme de birer dolgulu kart. */
.rn-page .rn-pick { background: var(--bg-surface, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); padding: 12px; margin-bottom: 14px; }
.rn-page .rn-tree { max-height: 260px; overflow: auto; background: var(--bg-page, transparent); }
.rn-page .rn-preview { margin-top: 16px; border-top: none; background: var(--bg-surface, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); padding: 12px; }
.rn-page .rn-table { max-height: 360px; } /* uzun listede kart içinde scroll (sayfa değil) */

/* Seçenek kartları: dolgulu zemin + 6 kart → geniş ekranda 3'lü grid (2 satır). */
.rn-page .rn-grid { grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 1180px) { .rn-page .rn-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 720px) { .rn-page .rn-grid { grid-template-columns: 1fr; } }
.rn-page .rn-sec { background: var(--bg-surface, var(--surface)); box-shadow: var(--shadow-xs, 0 1px 2px rgba(15,23,42,.04)); }
/* kök düğümü ağaçta vurgulu */
.rn-trow2.root { font-weight: 600; }

/* ═══ STANDART içerik-alanı araç sayfası başlığı (cila) — cv-head ═══
   PC-SHELL'de açılan tüm araçlar (Kopya Bulucu, Toplu Yeniden Adlandır, Arşiv
   Düzenleyici…) tek tip başlık çubuğu kullanır: geri-oku + ikon + başlık + sağda
   aksiyonlar. Inline-overlay başlığı (.ui-ovl--inline .ui-ovl__head, ui.css) bununla
   görsel olarak aynı değerlere hizalıdır. */
.cv-page { display: flex; flex-direction: column; height: 100%; min-height: 0; background: var(--bg-page, var(--bg, var(--surface))); }
.cv-body { flex: 1; min-height: 0; overflow: auto; padding: 16px 18px; }
/* İçerik kartı (toolPage card:true) — inline-overlay araçlarıyla aynı beyaz kart deseni. */
.cv-card { background: var(--bg-surface, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); padding: 16px; box-shadow: var(--shadow-xs, 0 1px 2px rgba(15,23,42,.04)); }
.cv-head { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-bottom: 1px solid var(--border-default, var(--border)); flex: 0 0 auto; background: var(--bg-surface, var(--surface)); }
.cv-head__back { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-sm, 7px); background: var(--bg-surface, var(--surface)); color: var(--text-secondary, var(--muted)); cursor: pointer; flex: 0 0 auto; }
.cv-head__back:hover { background: var(--bg-hover, color-mix(in srgb, var(--primary) 8%, transparent)); color: var(--text-primary, var(--fg)); }
.cv-head__title { display: flex; align-items: center; gap: 8px; font-size: 16px; font-weight: 600; color: var(--text-primary, var(--fg)); min-width: 0; }
.cv-head__title ui-icon { color: var(--primary); flex: 0 0 auto; }
.cv-head__title span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cv-head__actions { margin-left: auto; display: flex; align-items: center; gap: 8px; flex: 0 0 auto; }
/* Başlık aksiyon butonları TEK TİP yükseklik/yazı — karışık size (sm/md) yan yana farklı
   boyda durmasın (içerik-alanı araç sayfaları). Inline-overlay footer'ı da aynı hizaya gelir. */
.cv-head__actions ui-button .ui-btn,
.ui-ovl__foot--inline ui-button .ui-btn { height: 34px !important; min-height: 34px; padding: 0 14px !important; font-size: 13px !important; }
.ui-ovl--inline .ui-ovl__head .ui-ovl__foot--inline { align-items: center; }
/* Başlığa taşınan araç footer'ındaki select/etiket de buton yüksekliğiyle hizalı dursun
   (ör. video "Kaydet: [format]" — sağdaki birincil eylemle aynı satır/boy). */
.ui-ovl__foot--inline ui-select select { height: 34px; font-size: 13px; }
/* form-alanı alt boşluğu (ui-field margin) başlık çubuğunda hizayı bozuyordu → sıfırla. */
.ui-ovl__foot--inline .ui-field, .cv-head__actions .ui-field { margin-bottom: 0 !important; }
.ui-ovl__foot--inline .ve-fmt { gap: 8px; flex: 0 0 auto; flex-wrap: nowrap; min-width: max-content; white-space: nowrap; }
.ui-ovl__foot--inline .ve-fmt .ve-meta { color: var(--text-secondary, var(--muted)); }

/* ---- Araçlar nav + rename kapsam/ağaç + kompaktlaştırma ---- */
.navtool { background: transparent; border: 1px solid var(--border); padding: 7px 12px; border-radius: 8px; color: var(--fg); font-size: 13px; }
.navtool:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); border-color: var(--primary); color: var(--primary); }

/* P3: program menü çubuğu — yazı+ikon, buton görünümsüz (zemin yalnız hover/açıkken) */
.appmenu { display: flex; align-items: center; gap: 2px; margin-left: 6px; padding-left: 10px; border-left: 1px solid var(--border-default, var(--border)); }
.am-item { display: inline-flex; align-items: center; gap: 6px; background: none; border: none; padding: 6px 10px; border-radius: var(--radius-sm, 6px); font: inherit; font-size: 13.5px; font-weight: var(--font-medium, 500); color: var(--text-secondary, var(--muted)); cursor: pointer; transition: background var(--transition-fast, .12s), color var(--transition-fast, .12s); }
.am-item:hover { background: var(--bg-hover, color-mix(in srgb, var(--primary) 7%, transparent)); color: var(--text-primary, var(--fg)); }
.profilebtn ui-icon[name="chevron-down"] { color: var(--text-muted, var(--muted)); }
@media (max-width: 1100px) { .am-item span { display: none; } .am-item { padding: 6px 8px; } } /* dar: ikon-only (title var) */
@media (max-width: 760px) { .nav .user { display: none; } }

.rn-top { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; }
/* Kapsam sekmeleri: birleşik segment yerine AYRI pill butonlar (kit ile tutarlı).
   Aktif = primary dolgulu; pasif = kenarlıklı yüzey. Devre dışıyken sayı yine okunur. */
.rn-tabs { display: inline-flex; gap: 8px; }
.rn-tab { border: 1px solid var(--border-default, var(--border)); background: var(--bg-surface, var(--surface)); padding: 6px 14px; font-size: 13px; font-weight: 500; color: var(--text-secondary, var(--muted)); border-radius: var(--radius-sm, 7px); cursor: pointer; transition: background .12s, color .12s, border-color .12s; }
.rn-tab:hover:not(:disabled):not(.active) { border-color: var(--primary); color: var(--primary); }
.rn-tab.active { background: var(--primary); border-color: var(--primary); color: #fff; font-weight: 600; }
.rn-tab:disabled { opacity: .6; cursor: not-allowed; }
.rn-top select, .rn-top .rn-inline { font-size: 13px; }
.rn-top select { padding: 6px 28px 6px 8px; border: 1px solid var(--border); border-radius: 7px; background-color: var(--surface); color: var(--fg); }
.rn-pick { margin-bottom: 10px; }
.rn-pickinfo { font-size: 13px; color: var(--muted); margin-bottom: 6px; }
.rn-pickinfo b { color: var(--fg); }
.rn-tree { max-height: 150px; overflow: auto; border: 1px solid var(--border); border-radius: 8px; padding: 4px; }
.rn-trow2 { display: flex; align-items: center; gap: 6px; padding: 3px 6px; border-radius: 6px; cursor: pointer; font-size: 13px; white-space: nowrap; }
.rn-trow2:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.rn-trow2.sel { background: color-mix(in srgb, var(--primary) 16%, transparent); font-weight: 600; }
.rn-tog { width: 14px; text-align: center; color: var(--muted); font-size: 11px; }
.rn-tog.leaf { visibility: hidden; }
.rn-kids { padding-left: 16px; }

/* geçmiş dialog aksiyon butonları */
.rn-hist-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 13px; }
.rn-hist-row:last-child { border-bottom: none; }
.rn-hist-meta { color: var(--muted); font-size: 12px; }

/* ---- Ara / Disk Analizi ekranı ---- */
.se-body { margin: 8px 16px 24px; }
.se-row { display: grid; grid-template-columns: minmax(140px,1.3fr) minmax(160px,2fr) 130px 130px 150px; gap: 10px; align-items: center; padding: 7px 12px; border-bottom: 1px solid var(--border); font-size: 13px; }
.se-list { border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.se-list .se-row { cursor: pointer; }
.se-list .se-row:hover { background: color-mix(in srgb, var(--primary) 7%, transparent); }
.se-head { background: var(--surface); color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; border: 1px solid var(--border); border-bottom: none; border-radius: 10px 10px 0 0; }
.se-head + .se-list { border-radius: 0 0 10px 10px; border-top: none; }
.se-name { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.se-name mark, .se-path mark { background: color-mix(in srgb, var(--primary) 35%, transparent); color: inherit; border-radius: 3px; padding: 0 2px; }
.se-path { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.se-size { text-align: right; white-space: nowrap; }
.se-date { color: var(--muted); white-space: nowrap; }
.se-pct { position: relative; height: 16px; background: var(--bg); border-radius: 4px; overflow: hidden; }
.se-bar { position: absolute; left: 0; top: 0; bottom: 0; background: color-mix(in srgb, var(--primary) 45%, transparent); }
.se-pct i { position: relative; font-style: normal; font-size: 11px; padding-left: 6px; line-height: 16px; color: var(--fg); }
.se-foot { color: var(--muted); font-size: 13px; padding: 8px 4px; }
.se-anhead { font-size: 14px; margin: 4px 0 10px; }
.se-body h4 { margin: 16px 0 6px; font-size: 13px; color: var(--muted); }
.se-exts { border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.se-extrow { display: grid; grid-template-columns: 120px 1fr; gap: 10px; align-items: center; padding: 6px 12px; border-bottom: 1px solid var(--border); font-size: 13px; }
.se-extrow:last-child { border-bottom: none; }
.se-ename { font-weight: 600; }
@media (max-width: 760px) { .se-row { grid-template-columns: 1fr 90px 90px; } .se-path, .se-date { display: none; } }

/* ---- Ara: WizTree benzeri ağaç görünümü ---- */
.se-treebox { border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.se-trow { display: grid; grid-template-columns: minmax(160px,1.4fr) 120px 120px 150px; gap: 10px; align-items: center; padding: 5px 12px; border-bottom: 1px solid var(--border); font-size: 13px; }
.se-trow:last-child { border-bottom: none; }
.se-thead { background: var(--surface); color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
.se-titem { cursor: pointer; }
.se-titem:hover { background: color-mix(in srgb, var(--primary) 7%, transparent); }
.se-tc { display: flex; align-items: center; gap: 4px; min-width: 0; }
.se-indent { flex: none; }
.se-ttog { width: 16px; text-align: center; color: var(--muted); font-size: 11px; flex: none; }
.se-tlabel { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.se-tkids { } /* girinti satır bazında (depth) */

/* ---- Ara Increment 2: içerik snippet + sızıntı + stale ---- */
.se-item { border-bottom: 1px solid var(--border); }
.se-item:last-child { border-bottom: none; }
.se-item .se-row { border-bottom: none; }
.se-snips { padding: 2px 12px 8px 36px; display: flex; flex-direction: column; gap: 3px; }
.se-snip { display: flex; gap: 8px; align-items: baseline; font-size: 12px; }
.se-snip .se-ln { flex: none; min-width: 34px; text-align: right; color: var(--muted); font-family: ui-monospace, monospace; }
.se-snip code { font-family: ui-monospace, monospace; white-space: pre-wrap; word-break: break-word; color: var(--fg); }
.se-snip code mark, .se-name mark, .se-path mark { background: color-mix(in srgb, var(--primary) 35%, transparent); border-radius: 3px; padding: 0 2px; }
#se-status.stale { color: var(--danger); }
.se-leakfile { border: 1px solid var(--border); border-radius: 10px; margin: 8px 16px; overflow: hidden; }
.se-leakhead { background: var(--surface); padding: 8px 12px; font-weight: 600; cursor: pointer; display: flex; gap: 8px; align-items: baseline; }
.se-leakhead:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.se-leakpath { color: var(--muted); font-weight: 400; font-size: 12px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.se-leakhit { padding: 6px 12px; border-top: 1px solid var(--border); }
.se-leakhit .badge { margin-bottom: 4px; display: inline-block; }

/* ---- Kopya Bulucu ---- */
.dd-group { border: 1px solid var(--border); border-radius: 10px; margin: 8px 16px; overflow: hidden; }
.dd-ghead { background: var(--surface); padding: 8px 12px; font-size: 13px; display: flex; align-items: center; gap: 10px; }
.dd-ghead .dd-go { margin-left: auto; padding: 4px 10px; font-size: 13px; }
.dd-files { padding: 4px 0; }
.dd-file { display: grid; grid-template-columns: 18px 36px 48px 1fr 160px; gap: 8px; align-items: center; padding: 5px 12px; font-size: 13px; cursor: pointer; }
.dd-th { width: 44px; height: 44px; border-radius: 6px; object-fit: cover; background: var(--bg); border: 1px solid var(--border); }
.dd-th-ic { display: flex; align-items: center; justify-content: center; font-size: 20px; }
.dd-file:hover { background: color-mix(in srgb, var(--primary) 6%, transparent); }
.dd-keep { font-size: 11px; color: var(--muted); text-transform: uppercase; }
.dd-file input:checked ~ .dd-keep { color: var(--success); font-weight: 700; }
.dd-fpath { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dd-fdate { color: var(--muted); white-space: nowrap; text-align: right; }
.dd-qrow { display: grid; grid-template-columns: 1fr 200px auto; gap: 10px; align-items: center; padding: 7px 16px; border-bottom: 1px solid var(--border); font-size: 13px; }
.dd-qact { display: flex; gap: 6px; }
.dd-qact button { padding: 4px 10px; font-size: 13px; }

/* ---- Kopya Bulucu: görsel kıyas ---- */
.dd-cmp-wrap { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; max-height: 72vh; overflow: auto; padding: 4px; }
.dd-cmp-card { display: flex; flex-direction: column; gap: 6px; width: 340px; max-width: 44vw; border: 1px solid var(--border); border-radius: 10px; padding: 8px; cursor: pointer; }
.dd-cmp-card:has(input:checked) { border-color: var(--success); box-shadow: 0 0 0 2px color-mix(in srgb, var(--success) 35%, transparent); }
.dd-cmp-img { width: 100%; height: 320px; object-fit: contain; background: var(--bg); border-radius: 8px; }
.dd-cmp-ph { display: flex; align-items: center; justify-content: center; font-size: 32px; color: var(--muted); }
.dd-cmp-meta { display: flex; flex-direction: column; gap: 2px; font-size: 12px; }
.dd-cmp-meta .dd-fpath { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dd-cmp-keep { font-size: 13px; display: flex; align-items: center; gap: 6px; }
.dd-cmp-card:has(input:checked) .dd-cmp-keep { color: var(--success); font-weight: 700; }

/* ---- Arşiv Düzenleyici ---- */
.arc-dlg { display: flex; flex-direction: column; gap: 12px; }
/* İçerik-alanı (inline) modunda araç dialog'ları SAYFA gibi görünsün: gövde gri canvas +
   form içeriği beyaz kart (rename/dedup sayfalarıyla aynı desen). Gerçek modal (non-inline)
   ETKİLENMEZ. Tam-bleed medya/araç editörleri (.ve/.ae/.ie/.pdfx/.ocr) kendi düzenini korur. */
.ui-ovl--inline .ui-ovl__body { background: var(--bg-page, var(--bg, var(--surface))); }
.ui-ovl--inline .ui-ovl__body > div { background: var(--bg-surface, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); padding: 16px; box-shadow: var(--shadow-xs, 0 1px 2px rgba(15,23,42,.04)); }
.ui-ovl--inline .ui-ovl__body > .ve,
.ui-ovl--inline .ui-ovl__body > .ae,
.ui-ovl--inline .ui-ovl__body > .ie,
.ui-ovl--inline .ui-ovl__body > .pdfx,
.ui-ovl--inline .ui-ovl__body > .ocr { background: transparent; border: none; border-radius: 0; padding: 0; box-shadow: none; }
.arc-scope { display: flex; flex-direction: column; gap: 5px; font-size: 13px; color: var(--muted); }
.arc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.arc-field { display: flex; flex-direction: column; gap: 4px; }
.arc-field > label { font-size: 12px; font-weight: 500; color: var(--muted); display: flex; align-items: center; gap: 5px; }
.arc-dlg input:not([type="checkbox"]), .arc-dlg select { background-color: var(--surface); color: var(--fg); border: 1px solid var(--border); border-radius: 6px; padding: 6px 8px; font: inherit; font-size: 13px; width: 100%; }
.arc-dlg select { cursor: pointer; padding-right: 28px; }
.arc-tpl-inp { font-family: ui-monospace, monospace; }
.arc-example { font-size: 12px; color: var(--muted); font-family: ui-monospace, monospace; padding: 3px 8px; background: color-mix(in srgb, var(--primary) 6%, transparent); border-radius: 5px; }
.arc-example:empty { display: none; }
.arc-subsec { display: flex; flex-direction: column; gap: 6px; }
.arc-sublabel { font-size: 11px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; }
.arc-sublabel-hint { font-size: 11px; font-weight: 400; text-transform: none; letter-spacing: 0; }
.arc-chk { display: flex; align-items: center; gap: 7px; font-size: 13px; cursor: pointer; color: var(--fg); }
.arc-chk input[type="checkbox"] { flex-shrink: 0; width: 14px; height: 14px; cursor: pointer; }
.arc-presets { display: flex; flex-wrap: wrap; gap: 6px; }
.arc-chip { padding: 4px 12px; font-size: 12px; border-radius: 999px; background: var(--surface); border: 1px solid var(--border); color: var(--fg); cursor: pointer; white-space: nowrap; }
.arc-chip:hover { background: color-mix(in srgb, var(--primary) 10%, transparent); border-color: var(--primary); color: var(--primary); }
.arc-tokens { display: flex; flex-wrap: wrap; gap: 5px; }
.arc-tok { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; background: color-mix(in srgb, var(--primary) 10%, transparent); border-radius: 6px; cursor: pointer; }
.arc-tok code { font-family: ui-monospace, monospace; font-size: 11px; color: var(--primary); }
.arc-tok-name { font-size: 11px; color: var(--muted); }
.arc-tok:hover { background: color-mix(in srgb, var(--primary) 22%, transparent); }
.arc-icode { font-family: ui-monospace, monospace; font-size: 11px; background: color-mix(in srgb, var(--primary) 10%, transparent); padding: 1px 5px; border-radius: 4px; color: var(--primary); }
.arc-actions { display: flex; align-items: center; gap: 12px; }
.arc-sum { font-size: 13px; color: var(--muted); }
.arc-tbl { max-height: 36vh; overflow: auto; border: 1px solid var(--border); border-radius: 8px; }
.arc-tbl:empty { display: none; }
.arc-row { display: grid; grid-template-columns: 1fr 18px 1fr auto auto; gap: 8px; align-items: center; padding: 5px 10px; font-size: 12px; border-bottom: 1px solid var(--border); }
.arc-row:last-child { border-bottom: none; }
.arc-src, .arc-dst { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.arc-dst { color: var(--fg); }
.arc-arr { color: var(--muted); text-align: center; }
.arc-badge { font-size: 11px; padding: 1px 7px; border-radius: 999px; white-space: nowrap; }
.arc-t { background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--primary); }
.arc-warn { background: color-mix(in srgb, #d97706 20%, transparent); color: #d97706; }
.arc-hist { display: flex; flex-direction: column; }
.arc-hrow { display: flex; align-items: center; gap: 12px; padding: 9px 4px; border-bottom: 1px solid var(--border); }
.arc-hmeta { flex: 1; font-size: 13px; }
.arc-hsub { font-size: 12px; color: var(--muted); margin-top: 2px; }


/* ---- Kullanıcı Yönetimi ---- */
.usr-dlg { display: flex; flex-direction: column; gap: 12px; }
.usr-dlg select { background-color: var(--surface); color: var(--fg); border: 1px solid var(--border); border-radius: 6px; padding: 5px 28px 5px 8px; font: inherit; font-size: 13px; }
.usr-add { display: grid; grid-template-columns: 1.4fr 1fr 1fr 90px auto; gap: 8px; align-items: center; }
.usr-add input { color: var(--fg); }
.usr-list { border: 1px solid var(--border); border-radius: 8px; overflow: hidden; max-height: 56vh; overflow-y: auto; }
.usr-row { display: grid; grid-template-columns: 1.6fr 1fr 100px 90px 60px 90px; gap: 8px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.usr-row:last-child { border-bottom: none; }
.usr-head { background: var(--surface); color: var(--muted); font-size: 12px; text-transform: uppercase; letter-spacing: .03em; }
.usr-email { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.usr-row select.usr-r { padding: 4px 28px 4px 6px; font-size: 12px; }
.usr-act { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--muted); }
.usr-act input { width: auto; }
.usr-ops { display: flex; gap: 6px; justify-content: flex-end; align-items: center; }

/* ---- Kök Erişimleri (paylaşım) ---- */
.ra-add { display: grid; grid-template-columns: auto 1fr auto auto; gap: 8px; align-items: center; margin: 10px 0; }
.ra-row { display: grid; grid-template-columns: 1fr 120px auto; gap: 8px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.ra-row:last-child { border-bottom: none; }
.ra-perm { color: var(--muted); }
/* ---- Gruplar / Ekipler ---- */
.grp-add { display: grid; grid-template-columns: 1fr auto; gap: 8px; margin-bottom: 10px; }
.grp-cols { display: grid; grid-template-columns: 1fr 1.2fr; gap: 12px; }
.grp-row { display: grid; grid-template-columns: 1fr auto auto; gap: 8px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; cursor: default; }
.grp-row:last-child { border-bottom: none; }
.grp-row.sel { background: color-mix(in srgb, var(--primary) 12%, transparent); }
.grp-nm { cursor: pointer; font-weight: 600; }
.grp-mc { color: var(--muted); font-size: 12px; }
.grp-detail { border: 1px solid var(--border); border-radius: 8px; padding: 10px; }
.grp-dh { font-weight: 600; margin-bottom: 8px; }
.grp-addm { display: grid; grid-template-columns: 1fr 100px auto; gap: 6px; margin-bottom: 8px; }
.grp-mrow { display: grid; grid-template-columns: 1fr auto auto; gap: 8px; align-items: center; padding: 6px 4px; border-bottom: 1px solid var(--border); font-size: 13px; }
.grp-mrow:last-child { border-bottom: none; }
.ra-head { display: flex; align-items: center; gap: 8px; }

/* ---- Herkese açık toggle ---- */
.ra-pub { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); margin: 8px 0; }
.ra-pub input { width: auto; }

/* ---- Diskler / Yerel Kök Ekle ---- */
.dsk-vols { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 10px; }
.dsk-vol { display: flex; flex-direction: column; align-items: flex-start; gap: 2px; padding: 8px 12px; min-width: 150px; text-align: left; background: var(--surface); border: 1px solid var(--border); border-radius: 8px; cursor: pointer; color: var(--fg); }
.dsk-vol:hover { border-color: var(--primary); }
.dsk-dev { font-weight: 700; }
.dsk-lbl { font-size: 12px; color: var(--muted); }
.dsk-free { font-size: 11px; color: var(--muted); }
.dsk-pathbar { display: grid; grid-template-columns: auto 1fr; gap: 8px; margin-bottom: 6px; }
.dsk-nav .usr-list { max-height: 30vh; }
.dsk-dir { padding: 6px 10px; border-bottom: 1px solid var(--border); font-size: 13px; cursor: pointer; }
.dsk-dir:last-child { border-bottom: none; }
.dsk-dir:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.dsk-add { display: grid; grid-template-columns: 1fr auto auto; gap: 8px; align-items: center; margin-top: 10px; }
.dsk-wr { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--muted); white-space: nowrap; }
.dsk-wr input { width: auto; }
.dsk-cur { margin-top: 8px; font-size: 12px; color: var(--muted); word-break: break-all; }

/* ---- Cihaz switch (header) + cihaz dialog ---- */
/* Custom dropdown (native select yerine; durum noktası + ui-icon). */
.device-sel { display: inline-flex; align-items: center; gap: 6px; padding: 5px 8px; border-radius: 8px; border: 1px solid var(--border-default, var(--border)); background: var(--bg-surface, var(--surface)); color: var(--fg); font: inherit; font-size: 13px; max-width: 220px; cursor: pointer; transition: background var(--transition-fast, .12s), border-color var(--transition-fast, .12s); }
.device-sel:hover { border-color: var(--primary); background: var(--bg-hover, color-mix(in srgb, var(--primary) 6%, transparent)); }
.device-sel .dev-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.device-sel .dev-caret { color: var(--text-muted, var(--muted)); flex: 0 0 auto; }
.dev-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; background: var(--text-muted, #94a3b8); }
.dev-dot.on { background: var(--color-success, #16a34a); box-shadow: 0 0 0 2px color-mix(in srgb, var(--color-success, #16a34a) 25%, transparent); }
.dev-dot.off { background: var(--text-muted, #94a3b8); }
.dev-pop { z-index: var(--z-popover, 1100); background: var(--bg-elevated, var(--surface)); border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-lg, 10px); box-shadow: var(--shadow-lg, 0 8px 24px rgba(15,23,42,.16)); padding: 5px; display: flex; flex-direction: column; gap: 2px; animation: ui-scale-in var(--transition, .15s) var(--ease-spring, ease) both; max-height: 60vh; overflow: auto; }
.dev-pop__row { display: flex; align-items: center; gap: 8px; padding: 7px 10px; border: none; background: none; border-radius: var(--radius-sm, 7px); cursor: pointer; font: inherit; font-size: 13px; color: var(--text-primary, var(--fg)); text-align: left; }
.dev-pop__row:hover { background: var(--bg-hover, color-mix(in srgb, var(--primary) 8%, transparent)); }
.dev-pop__row.is-sel { background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--primary); }
.dev-pop__name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dev-pop__ok { color: var(--primary); flex: 0 0 auto; }
/* Disk ekle — "Üst klasör" butonu belirgin olsun: outline + primary renkli ikon/metin. */
#dsk-up .ui-btn { color: var(--primary); border-color: color-mix(in srgb, var(--primary) 45%, var(--border-default, var(--border))); }
#dsk-up .ui-btn:hover { background: color-mix(in srgb, var(--primary) 10%, transparent); border-color: var(--primary); }
#dsk-up ui-icon { color: var(--primary); }
.dev-hint { font-size: 12px; color: var(--muted); background: color-mix(in srgb, var(--primary) 6%, transparent); padding: 8px 10px; border-radius: 8px; margin-bottom: 10px; }
.dev-sec { margin-bottom: 12px; }
.dev-sec > b { display: block; margin-bottom: 6px; font-size: 13px; }
.dev-row { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.dev-row:last-child { border-bottom: none; }
.dev-nm { font-weight: 600; }
.dev-plat { font-weight: 400; color: var(--muted); font-size: 12px; }
.dev-st { font-size: 12px; color: var(--muted); }
.dev-st-pending { color: #d97706; }
.dev-st-approved { color: var(--success); }
.dev-st-revoke_requested { color: #d97706; }
.dev-wait { font-size: 12px; color: var(--muted); }

/* ---- Profil + header avatar ---- */
.profilebtn { display: flex; align-items: center; gap: 8px; background: transparent; border: 1px solid transparent; padding: 4px 8px; border-radius: 8px; cursor: pointer; }
.profilebtn:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.nav-avatar { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; background: var(--border); }
.prof { display: flex; flex-direction: column; gap: 14px; }
.prof-top { display: flex; align-items: center; gap: 14px; }
.prof-ava { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.prof-img, #prof-img { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; background: var(--bg); border: 1px solid var(--border); }
.prof-img-ph { display: flex; align-items: center; justify-content: center; font-size: 34px; }
.prof-avbtn { font-size: 12px; color: var(--primary); cursor: pointer; }
.prof-name { font-size: 18px; font-weight: 700; }
.prof-sub { font-size: 13px; color: var(--muted); }
.prof-inactive { color: var(--danger); }
.prof-sec { border: 1px solid var(--border); border-radius: 10px; padding: 12px; }
.prof-sec > b { display: block; margin-bottom: 10px; }
.prof-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.prof-grid label, .prof-full { display: flex; flex-direction: column; gap: 5px; font-size: 12px; color: var(--muted); }
.prof-grid input, .prof-full textarea { color: var(--fg); }
.prof-full { margin-top: 10px; }
.prof-actions { margin-top: 10px; display: flex; justify-content: flex-end; }
.prof-hint { font-size: 12px; color: var(--muted); margin-bottom: 8px; }

/* ---- Çöp Kutusu ---- */
.trash-dlg { display: flex; flex-direction: column; gap: 10px; }
.trash-bar { display: flex; align-items: center; justify-content: space-between; }
.trash-info { font-size: 13px; color: var(--muted); }
.trash-row { display: grid; grid-template-columns: 1.3fr 1.6fr auto auto; gap: 10px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.trash-row:last-child { border-bottom: none; }
.trash-nm { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.trash-path { color: var(--muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.trash-meta { color: var(--muted); white-space: nowrap; font-size: 12px; }
.trash-act { display: flex; gap: 6px; align-items: center; }

/* ---- Disk analizi: canlı tarama göstergesi ---- */
.se-live { color: #d97706; font-weight: 600; }
.se-mini { padding: 2px 8px; font-size: 12px; margin-left: 8px; }

/* ---- İndeks / Analiz Yönetimi ---- */
.idx-mgr { display: flex; flex-direction: column; gap: 6px; }
.idx-sec { margin-bottom: 10px; }
.idx-gh { font-weight: 700; font-size: 13px; margin: 6px 0; color: var(--fg); }
.idx-row { display: grid; grid-template-columns: 1.1fr 1.4fr auto; gap: 10px; align-items: center; padding: 7px 10px; border-bottom: 1px solid var(--border); font-size: 13px; }
.idx-row:last-child { border-bottom: none; }
.idx-nm { font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.idx-st { font-size: 12px; color: var(--muted); }
.idx-ok { color: var(--success); }
.idx-stale { color: #d97706; }
.idx-none { color: var(--muted); }
.idx-live { color: #2563eb; }
.idx-act { display: flex; gap: 6px; justify-content: flex-end; flex-wrap: wrap; align-items: center; }

/* ===== Alt çubuk (footer): durum çubuğu + canlı işlem paneli (Windows gezgini / FileZilla tarzı) ===== */
.app-foot { flex: 0 0 auto; display: flex; flex-direction: column; z-index: var(--z-dropdown); }

/* P2: durum çubuğu DS token'larıyla */
.statusbar { display: flex; align-items: center; gap: 12px; height: 34px; padding: 0 12px; background: var(--bg-surface, var(--surface)); border-top: 1px solid var(--border-default, var(--border)); font-size: var(--text-sm, 12.5px); color: var(--text-muted, var(--muted)); box-shadow: 0 -2px 8px rgba(0,0,0,.04); }
.statusbar .spacer { flex: 1; }
.sb-brand { display: inline-flex; align-items: center; gap: 5px; color: var(--fg); white-space: nowrap; }
.sb-brand b { font-weight: 700; }
.sb-info { color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; padding-left: 18px; }
.sb-widgets { display: inline-flex; align-items: center; gap: 10px; }
.sb-ic { padding: 2px 7px; min-width: 28px; height: 24px; line-height: 1; border: 1px solid transparent; background: transparent; color: var(--muted); border-radius: 6px; font-size: 14px; display: inline-flex; align-items: center; justify-content: center; gap: 3px; }
.sb-ic:hover { background: var(--bg-hover, var(--bg)); color: var(--text-primary, var(--fg)); border-color: var(--border-default, var(--border)); }
.sb-ic.active { color: var(--color-primary, var(--primary)); border-color: transparent; background: var(--color-primary-soft, color-mix(in srgb, var(--primary) 10%, transparent)); }
.sb-ic.sb-dim { opacity: .4; }
.sb-ic.running .sb-jglyph { animation: sbpulse 1s ease-in-out infinite; }
@keyframes sbpulse { 50% { opacity: .35; } }
.sb-jcount { font-size: 10px; font-weight: 700; min-width: 14px; height: 14px; padding: 0 3px; border-radius: 7px; background: var(--border); color: var(--fg); display: none; align-items: center; justify-content: center; }
.sb-jcount.on { display: inline-flex; background: var(--primary); color: #fff; }
.sb-clock { font-variant-numeric: tabular-nums; color: var(--fg); white-space: nowrap; min-width: 64px; text-align: right; }

.jobs-panel { background: var(--surface); border-top: 1px solid var(--border); box-shadow: 0 -6px 18px rgba(0,0,0,.10); max-height: 240px; display: flex; flex-direction: column; }
.jobs-panel[hidden] { display: none; }
.jp-head { display: flex; align-items: center; gap: 8px; padding: 7px 12px; border-bottom: 1px solid var(--border); font-size: 13px; }
.jp-head .spacer { flex: 1; }
.jp-title { font-weight: 600; }
.jp-close { padding: 2px 8px; background: transparent; border: none; color: var(--muted); font-size: 14px; }
.jp-close:hover { color: var(--fg); }
.jp-body { overflow-y: auto; padding: 6px 12px 10px; }
.jp-empty { color: var(--muted); text-align: center; padding: 18px 8px; font-size: 13px; }
.jp-sep { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .04em; margin: 10px 0 4px; }
.jp-row { display: grid; grid-template-columns: 110px 1fr 44px minmax(120px, 1.4fr); align-items: center; gap: 10px; padding: 5px 0; font-size: 12.5px; }
.jp-jtype { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.jp-bar { position: relative; height: 8px; border-radius: 5px; background: var(--bg); overflow: hidden; border: 1px solid var(--border); }
.jp-bar > span { position: absolute; left: 0; top: 0; bottom: 0; background: var(--primary); transition: width .3s ease; }
.jp-bar.ok > span { background: #16a34a; }
.jp-bar.err > span { background: var(--danger); }
.jp-bar.indet > span { width: 35% !important; animation: jpindet 1.1s ease-in-out infinite; }
@keyframes jpindet { 0% { left: -35%; } 100% { left: 100%; } }
.jp-pct { font-variant-numeric: tabular-nums; text-align: right; color: var(--muted); }
.jp-detail { color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.jp-row.failed .jp-detail { color: var(--danger); }

/* ===== Detay paneli thumbnail büyütme + 16:9 kırpılmamış ===== */
.workspace.detail-right .detail { flex: 0 0 340px; }
.detail-thumb { height: auto; aspect-ratio: 16 / 9; min-height: 170px; max-height: 440px; width: 100%; }
.detail-thumb img { width: 100%; height: 100%; object-fit: contain; }
.detail-thumb .ic-lg { font-size: 88px; line-height: 1; }

/* Detay paneli — çoklu seçim & boş durum görseli */
.detail-thumb.multi, .detail-thumb.empty-thumb { background: var(--bg); }
.detail-thumb.empty-thumb .ic-lg { opacity: .35; }
.detail-stack { position: relative; width: 92px; height: 104px; }
.detail-stack i { position: absolute; width: 70px; height: 90px; border-radius: 9px; background: linear-gradient(155deg, #5cb0ff, #2f7fe0); box-shadow: 0 3px 8px rgba(0,0,0,.22); border: 1px solid rgba(255,255,255,.35); }
.detail-stack i:nth-child(1) { right: 0; top: 0; }
.detail-stack i:nth-child(2) { left: 0; bottom: 0; }
.detail-multi-note { color: var(--muted); font-size: 13px; line-height: 1.45; background: var(--bg); border: 1px solid var(--border); border-radius: 8px; padding: 12px 14px; margin-top: 4px; }

/* Tam-yükseklik uygulama kabuğu: nav + #screen (esner) + footer; alanlar footer'a kadar uzar */
html, body { height: 100%; }
#app { height: 100vh; display: flex; flex-direction: column; }
#screen { flex: 1 1 auto; min-height: 0; overflow: auto; display: flex; flex-direction: column; }
.files-view { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: row; }
.fm-main { flex: 1 1 auto; min-width: 0; min-height: 0; display: flex; flex-direction: column; }

/* ---- Explorer tarzı sol panel (docs/12 · F1) ---- */
.fm-side { position: relative; flex: 0 0 auto; width: var(--sidebar-w, 248px); min-width: 200px; max-width: 380px; display: flex; flex-direction: column; border-right: 1px solid var(--border-default, var(--border)); background: var(--bg-surface, var(--surface)); }
.fm-side__scroll { flex: 1 1 auto; min-height: 0; overflow-y: auto; padding: 10px 6px; }
.fm-side__resizer { position: absolute; right: -3px; top: 0; bottom: 0; width: 7px; cursor: ew-resize; touch-action: none; z-index: 2; }
.fm-side__resizer:hover { background: color-mix(in srgb, var(--primary) 25%, transparent); }
.fm-sec { margin-bottom: 14px; }
.fm-sec__title { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); font-weight: 600; padding: 2px 10px 6px; }
.fm-node { display: flex; align-items: center; gap: 4px; padding: 5px 6px 5px calc(6px + var(--lvl, 0) * 14px); border-radius: 7px; cursor: pointer; color: var(--fg); font-size: 13.5px; user-select: none; }
.fm-node:hover { background: var(--bg-hover, color-mix(in srgb, var(--primary) 7%, transparent)); }
.fm-node.is-active { background: var(--color-primary-soft, color-mix(in srgb, var(--primary) 14%, transparent)); color: var(--color-primary, var(--primary)); font-weight: var(--font-semibold, 600); }
.fm-node__tw { flex: none; width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; background: none; border: none; padding: 0; color: var(--muted); cursor: pointer; border-radius: 4px; }
.fm-node__tw:hover { background: color-mix(in srgb, var(--primary) 12%, transparent); color: var(--primary); }
.fm-node__tw.is-loading { animation: spin 1s linear infinite; }
.fm-node__ic { flex: none; display: inline-flex; color: var(--muted); }
.fm-node.is-active .fm-node__ic { color: var(--primary); }
.fm-node__lbl { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.fm-kids__empty { padding: 3px 10px 3px 34px; font-size: 12px; color: var(--muted); }
.fm-node--pin { padding-left: 10px; }
.fm-node__x { flex: none; width: 20px; height: 20px; display: inline-flex; align-items: center; justify-content: center; background: none; border: none; padding: 0; border-radius: 4px; color: var(--muted); cursor: pointer; opacity: 0; transition: opacity .12s; }
.fm-node--pin:hover .fm-node__x { opacity: 1; }
.fm-node__x:hover { background: color-mix(in srgb, var(--danger) 14%, transparent); color: var(--danger); }
.fm-side__foot { flex: none; border-top: 1px solid var(--border); padding: 6px; display: flex; flex-direction: column; gap: 1px; }
.fm-foot__btn { display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: none; border: none; border-radius: 7px; color: var(--fg); font-size: 13px; cursor: pointer; text-align: left; }
.fm-foot__btn:hover { background: color-mix(in srgb, var(--primary) 8%, transparent); }
.fm-files { flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; }

/* ---- P1 (docs/13): Windows tarzı üst düzen — yol çubuğu + UI kit toolbar ---- */
.fm-pathbar { display: flex; align-items: center; gap: 6px; padding: 7px 12px; border-bottom: 1px solid var(--border-default, var(--border)); background: var(--bg-surface, var(--surface)); }
.fm-pathbar .crumbs { flex: 1 1 auto; min-width: 0; padding: 5px 10px; margin: 0; border: 1px solid var(--border-default, var(--border)); border-radius: var(--radius-md, 8px); background: var(--bg-sunken, var(--bg)); overflow-x: auto; flex-wrap: nowrap; white-space: nowrap; scrollbar-width: none; }
.fm-pathbar .crumbs::-webkit-scrollbar { display: none; }
.fm-search { flex: 0 0 auto; }
.fm-search .filter-input { width: 220px; height: 32px; border-radius: 8px; }
.fm-toolbar { display: flex; align-items: center; gap: 3px; padding: 5px 12px; border-bottom: 1px solid var(--border-default, var(--border)); background: var(--bg-surface, var(--surface)); flex-wrap: wrap; }
.fm-toolbar .spacer { flex: 1; }
.fm-tb-sep { width: 1px; height: 22px; background: var(--border-default, var(--border)); margin: 0 5px; flex: none; }
.fm-net { flex: 1 1 auto; min-height: 0; overflow: auto; padding: 14px 16px; }
/* PC-SHELL içerik görünümü (yedek/senkron/iş/ara/dedup) — kabuk içinde, kaydırılabilir */
.fm-view { flex: 1 1 auto; min-height: 0; overflow: auto; display: flex; flex-direction: column; }
.fm-view > * { flex: 1 1 auto; min-height: 0; }
.fm-files[hidden], .fm-net[hidden], .fm-view[hidden] { display: none; } /* display:flex hidden'ı ezmesin */

/* ---- F5: responsive sidebar ---- */
.fm-side__top { flex: none; display: flex; justify-content: flex-end; padding: 6px 6px 0; }
.fm-side__fold { width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; background: none; border: none; border-radius: 6px; color: var(--muted); cursor: pointer; }
.fm-side__fold:hover { background: color-mix(in srgb, var(--primary) 10%, transparent); color: var(--primary); }
.toolbar .fm-burger { display: none; } /* .toolbar button kuralından yüksek özgüllük şart */

/* mini (yalnız ikon) mod — 900–1200 arası varsayılan; toggle ile her genişlikte */
.fm-side.is-mini { width: var(--sidebar-w-collapsed, 64px) !important; min-width: var(--sidebar-w-collapsed, 64px); }
.fm-side.is-mini .fm-node__lbl, .fm-side.is-mini .fm-sec__title, .fm-side.is-mini .fm-node__tw,
.fm-side.is-mini .fm-node__x, .fm-side.is-mini .fm-kids, .fm-side.is-mini .fm-side__resizer,
.fm-side.is-mini .fm-foot__lbl, .fm-side.is-mini .fm-kids__empty { display: none; }
.fm-side.is-mini .fm-node { justify-content: center; padding: 9px 0; }
.fm-side.is-mini .fm-foot__btn { justify-content: center; padding: 9px 0; }
.fm-side.is-mini .fm-side__top { justify-content: center; }

/* ≤900px (tablet/mobil): sidebar overlay drawer — ☰ açar, backdrop kapatır */
.fm-side-backdrop { position: fixed; inset: 0; background: rgba(0, 0, 0, .42); z-index: calc(var(--z-drawer, 90) - 1); }
.fm-side-backdrop[hidden] { display: none; }
@media (min-width: 901px) { .fm-side-backdrop { display: none !important; } }
@media (max-width: 900px) {
  .toolbar .fm-burger { display: inline-flex; }
  .fm-side, .fm-side.is-mini { position: fixed; left: 0; top: 0; bottom: 0; z-index: var(--z-drawer, 90); width: 280px !important; min-width: 280px; transform: translateX(-100%); transition: transform .22s ease; box-shadow: 0 12px 40px rgba(0, 0, 0, .3); }
  .fm-side.is-open, .fm-side.is-mini.is-open { transform: none; }
  .fm-side .fm-side__resizer, .fm-side .fm-side__top { display: none; }
  /* overlay'de mini mod uygulanmaz (her zaman tam genişlik) */
  .fm-side.is-mini .fm-node__lbl, .fm-side.is-mini .fm-foot__lbl { display: inline; }
  .fm-side.is-mini .fm-sec__title, .fm-side.is-mini .fm-kids__empty { display: block; }
  .fm-side.is-mini .fm-node__tw, .fm-side.is-mini .fm-node__x { display: inline-flex; }
  .fm-side.is-mini .fm-kids:not([hidden]) { display: block; }
  .fm-side.is-mini .fm-node { justify-content: flex-start; padding: 8px 6px 8px calc(6px + var(--lvl, 0) * 14px); }
  .fm-side.is-mini .fm-foot__btn { justify-content: flex-start; padding: 9px 10px; }
  /* dokunma hedefleri */
  .fm-node { padding-top: 8px; padding-bottom: 8px; }
  .fm-node__tw { width: 26px; height: 26px; }
  .fm-foot__btn { padding: 10px; }
}

/* Görüntüleme modu (gezinmeli önizleme) */
.viewer { display: flex; flex-direction: column; gap: 10px; }
.vw-head { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--muted); }
.vw-name { font-weight: 600; color: var(--fg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vw-count { margin-left: auto; font-variant-numeric: tabular-nums; }
.vw-main { position: relative; display: flex; align-items: center; justify-content: center; min-height: 62vh; }
.vw-stage { flex: 1; display: flex; align-items: center; justify-content: center; max-height: 76vh; overflow: auto; }
.vw-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 50%; border: 1px solid var(--border); background: var(--surface); color: var(--fg); font-size: 26px; line-height: 1; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,.15)); z-index: 2; opacity: .92; }
.vw-nav:hover { background: var(--bg-hover, rgba(0,0,0,.05)); opacity: 1; }
.vw-prev { left: 4px; } .vw-next { right: 4px; }

/* Görüntüleyici alt bilgi + zoom çubuğu */
.vw-bottom { display: flex; align-items: center; gap: 12px; border-top: 1px solid var(--border); padding-top: 8px; font-size: 13px; color: var(--muted); }
.vw-info b { color: var(--fg); font-weight: 600; }
.vw-zoom { display: flex; align-items: center; gap: 8px; }
.vw-zv { min-width: 42px; text-align: right; font-variant-numeric: tabular-nums; color: var(--fg); }
.vw-range { -webkit-appearance: none; appearance: none; width: 130px; height: 6px; border-radius: 999px; background: var(--border-strong, var(--border)); outline: none; }
.vw-range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 22px; height: 16px; border-radius: 999px; background: var(--color-primary, var(--primary)); border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.35); cursor: grab; }
.vw-range::-moz-range-thumb { width: 22px; height: 16px; border-radius: 999px; background: var(--color-primary, var(--primary)); border: 2px solid #fff; box-shadow: 0 1px 4px rgba(0,0,0,.35); cursor: grab; }


.vw-actions { display: flex; align-items: center; gap: 2px; }
/* Nötr (yeni kit) görünüm: varsayılan tek renk, yalnız hover'da anlamlı renk */
.vw-actions #vwPrint .ui-iconbtn:hover { color: var(--color-info, var(--primary)); }
.vw-actions #vwShare .ui-iconbtn:hover { color: var(--color-primary, var(--primary)); }
.vw-actions #vwDel .ui-iconbtn:hover { color: var(--color-danger, var(--danger)); }

/* Önizleme/Görüntüleme — yeni UI Kit modal kabuğu (uiModal size=xl + viewer içeriği). Düzenle modalıyla aynı standart. */
.ui-ovl--viewer .ui-ovl__panel { height: 86vh; }
/* Gövde head/foot arasını DOLDURUR (flex:1) → orta alan sabit; dosya türüne göre daralıp uzamaz. */
.ui-ovl--viewer .ui-ovl__body { flex: 1 1 auto; min-height: 0; display: flex; padding: 12px 16px; overflow: hidden; }
.ui-ovl--viewer .viewer { flex: 1; min-height: 0; }
.ui-ovl--viewer .vw-main { flex: 1 1 auto; min-height: 0; overflow: hidden; align-items: stretch; }
.ui-ovl--viewer .vw-stage { flex: 1; min-height: 0; min-width: 0; height: 100%; overflow: hidden; max-height: none; align-items: center; justify-content: center; }
.ui-ovl--viewer .vw-stage .pv-img, .ui-ovl--viewer .vw-stage .pv-media { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.ui-ovl--viewer .vw-stage .pv-frame { width: 100%; height: 100%; border: 0; }
.ui-ovl--viewer .vw-stage .pv-text { width: 100%; height: 100%; overflow: auto; margin: 0; }

/* ============================================================
   P6 — Tablet dokunmatik geçişi  (pointer: coarse)
   Mouse kullanıcıları etkilenmez; dokunmatik ekranda:
   · Tüm kontroller ≥ 36 px (primer hedefler ≥ 44 px)
   · Hover-only gizlenen öğeler görünür olur
   · touch-action: manipulation ile çift-dokunuş gecikmesi kaldırılır
   ============================================================ */
@media (pointer: coarse) {
  /* Gezinme butonları: Geri / İleri / Yukarı / Yenile */
  .navicons { gap: 5px; }
  .navicon { width: 44px; height: 44px; font-size: 19px; border-radius: 10px; }

  /* Yol çubuğu arama kutusu */
  .fm-search .filter-input { height: 40px; }

  /* Durum çubuğu + ikon butonları */
  .statusbar { height: 44px; }
  .sb-ic { height: 36px; min-width: 36px; padding: 0 10px; font-size: 15px; }

  /* Sol panel — satır yüksekliği, genişlet oku, unpin, daralt */
  .fm-node { padding-top: 9px; padding-bottom: 9px; }
  .fm-node__tw { width: 32px; height: 32px; }
  /* Hover-only gizli unpin → her zaman görünür (azaltılmış opaklık) */
  .fm-node__x { width: 32px; height: 32px; opacity: 0.55; }
  .fm-node--pin:hover .fm-node__x,
  .fm-node--pin:focus-within .fm-node__x { opacity: 1; }
  .fm-side__fold { width: 36px; height: 36px; }
  .fm-foot__btn { padding: 10px 10px; }

  /* Dialog sekme çubuğu (yeniden adlandır vb.) */
  .rn-tab { padding: 10px 16px; }

  /* Arşiv chip'leri + token'lar */
  .arc-chip { padding: 8px 14px; font-size: 13px; }
  .arc-tok { padding: 7px 10px; }

  /* Görüntüleyici gezinme okları — zaten 46 px; hover-gizleme kaldırıldı */
  .vw-nav { opacity: 1; }

  /* Çift-dokunuş zoom gecikmesini kaldır */
  .navicon, .sb-ic,
  .fm-node, .fm-node__tw, .fm-node__x, .fm-foot__btn, .fm-side__fold,
  .arc-chip, .arc-tok, .rn-tab { touch-action: manipulation; }
}
