/* ═══════════════════════════════════════════════════════════
   EthOS — Additional App Styles
   Storage, Printer, Resources, Backup
   ═══════════════════════════════════════════════════════════ */

/* ─── Shared ─── */
.btn-green { color: var(--accent-green) !important; transition: all var(--transition-fast); }
.btn-green:hover { background: rgba(34, 197, 94, 0.15) !important; }
.btn-red { color: var(--danger) !important; transition: all var(--transition-fast); }
.btn-red:hover { background: rgba(239, 68, 68, 0.15) !important; }
.btn-orange { color: var(--accent-orange) !important; transition: all var(--transition-fast); }
.btn-orange:hover { background: rgba(245, 158, 11, 0.15) !important; }
.btn-purple { color: var(--accent-purple) !important; transition: all var(--transition-fast); }
.btn-purple:hover { background: rgba(139, 92, 246, 0.15) !important; }
.btn-cyan { color: var(--accent-cyan) !important; transition: all var(--transition-fast); }
.btn-cyan:hover { background: rgba(6, 182, 212, 0.15) !important; }

.fm-badge { display: inline-block; padding: 2px 8px; border-radius: var(--r-md); font-size: 0.75em; font-weight: 600; background: rgba(79,140,255,0.12); color: var(--accent); }
.fm-badge-green { background: rgba(34, 197, 94, 0.15); color: var(--accent-green); }
.fm-badge-dim { background: var(--overlay-3); color: var(--text-muted); }

.fm-input {
    background-color: var(--bg-deep, #0f1117);
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    padding: 8px 12px;
    color: var(--text);
    font-size: 0.9em;
}
select.fm-input {
    background-color: var(--bg-elevated); /* Match global standard */
    padding-right: 24px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 320 512'%3E%3Cpath fill='%2364748b' d='M31.3 192h257.3c17.8 0 26.7 21.5 14.1 34.1L174.1 354.8c-7.8 7.8-20.5 7.8-28.3 0L17.2 226.1C4.6 213.5 13.5 192 31.3 192z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 6px center;
    background-size: 8px;
}
.fm-input:focus { outline: none; border-color: var(--accent); }

.fm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9em;
}
.fm-table th {
    text-align: left;
    font-size: 0.75em;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-muted);
    padding: 8px 10px;
    border-bottom: 1px solid var(--border);
}
.fm-table td { padding: 10px; border-bottom: 1px solid var(--border); }
.fm-table tr:hover td { background: var(--overlay-2); }
.fm-selected td { background: rgba(79,140,255,0.1) !important; }

.hidden { display: none !important; }

/* ═══ Storage App (card layout) ═══ */
.storage-app { height: 100%; display: flex; flex-direction: column; padding: 12px; overflow-y: auto; }
.storage-toolbar { display: flex; align-items: center; gap: 8px; padding-bottom: 12px; border-bottom: 1px solid var(--border); margin-bottom: 12px; }
.storage-status { color: var(--text-muted); font-size: 0.85em; margin-left: auto; }
.storage-form-row { display: flex; gap: 10px; align-items: center; margin-bottom: 8px; flex-wrap: wrap; }
.storage-form-row label { font-size: 0.85em; color: var(--text-muted); white-space: nowrap; }
.storage-check { display: flex; align-items: center; gap: 6px; font-size: 0.9em; cursor: pointer; }
.storage-check input { accent-color: var(--accent); }
.storage-app .fm-toolbar-btn:not(.btn-sm) { width: auto; height: auto; padding: 6px 12px; gap: 6px; font-size: 12px; white-space: nowrap; }
.storage-app .fm-toolbar-btn.btn-sm { width: auto; height: auto; padding: 4px 10px; white-space: nowrap; }

/* Drive groups */
.st-groups { flex: 1; overflow-y: auto; }
.st-group { margin-bottom: 16px; }
.st-group-header {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 4px; font-size: 12px; font-weight: 600;
    color: var(--text-muted); text-transform: uppercase; letter-spacing: .5px;
}
.st-group-toggle { cursor: pointer; border-radius: var(--r-sm); transition: all var(--transition-fast); }
.st-group-toggle:hover { background: var(--overlay-2); }
.st-group-count {
    font-size: 10px; font-weight: 500; background: var(--overlay-3);
    padding: 1px 8px; border-radius: var(--r-md); margin-left: 4px;
}
.st-group-chevron { font-size: 10px; margin-left: auto; transition: transform var(--transition), box-shadow var(--transition); }
.st-group-label { min-width: 0; }

/* Drive cards */
.st-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 10px; }
.st-card {
    padding: 14px; border-radius: var(--r-md);
    border: 1px solid var(--border); background: var(--overlay-1);
    cursor: pointer; transition: all var(--transition-fast);
}
.st-card:hover { border-color: rgba(79,140,255,.3); background: rgba(79,140,255,.03); }
.st-card-selected { border-color: var(--accent) !important; background: rgba(79,140,255,.06) !important; box-shadow: 0 0 0 1px var(--accent); }
.st-card-header { display: flex; align-items: flex-start; gap: 10px; margin-bottom: 10px; }
.st-card-header > i { font-size: 18px; margin-top: 2px; flex-shrink: 0; }
.st-card-name { font-weight: 600; font-size: 14px; line-height: 1.2; }
.st-card-sub { font-size: 11px; color: var(--text-muted); line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.st-card-usage { margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.st-card-bar { flex: 1; height: 5px; background: var(--overlay-3); border-radius: var(--r-sm); overflow: hidden; }
.st-card-bar-fill { height: 100%; border-radius: var(--r-sm); transition: width var(--transition-slow); }
.st-card-pct { font-size: 12px; font-weight: 600; min-width: 32px; text-align: right; }
.st-card-mount { font-size: 11px; color: var(--text-secondary); margin-bottom: 8px; display: flex; align-items: center; gap: 5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.st-card-mount > i { font-size: 10px; }
.st-unmounted { color: var(--text-muted); opacity: .6; }
.st-card-badges { display: flex; flex-wrap: wrap; gap: 4px; }
.st-card-badges .fm-badge { font-size: 10px; }

/* Action panel */
.st-actions {
    padding: 14px 16px; margin-top: 4px;
    background: var(--overlay-1); border: 1px solid var(--border);
    border-radius: var(--r-md);
}
.st-actions-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.st-actions-title { font-weight: 600; font-size: 13px; }
.st-actions-btns { display: flex; gap: 6px; flex-wrap: wrap; }

/* Stale fstab */
.st-stale-box { padding: 12px; background: rgba(239,68,68,.04); border: 1px solid rgba(239,68,68,.15); border-radius: var(--r-md); margin-top: 10px; }
.st-stale-header { font-size: 12px; font-weight: 600; color: var(--danger); margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.st-stale-row { font-size: 12px; display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.st-stale-dev { font-family: monospace; font-size: 11px; color: var(--text-muted); }

/* ═══ Sharing / Samba App ═══ */
.sharing-app { height: 100%; display: flex; flex-direction: column; padding: 16px; overflow-y: auto; }
.sharing-app .fm-toolbar-btn:not(.btn-sm) { width: auto; height: auto; padding: 6px 12px; gap: 6px; font-size: 12px; white-space: nowrap; }
.sharing-app .fm-toolbar-btn.btn-sm { width: auto; height: auto; padding: 4px 10px; white-space: nowrap; }
.sharing-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.sharing-header h3 { font-size: 1em; display: flex; align-items: center; gap: 8px; }
.sharing-form { padding: 16px; background: var(--overlay-1); border-radius: var(--r-md); margin-top: 12px; border: 1px solid var(--border); }
.sharing-form h4 { margin-bottom: 12px; font-size: .95em; }
.sharing-pw { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); }
.sharing-pw h4 { font-size: .95em; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }

/* ═══ Disk Analytics (in File Manager) ═══ */
.fm-ana-panel { padding: 12px 16px; height: 100%; display: flex; flex-direction: column; overflow: hidden; }
.fm-ana-header { margin-bottom: 10px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.fm-ana-breadcrumbs { display: flex; align-items: center; flex-wrap: wrap; gap: 0; font-size: 12px; padding: 4px 0; }
.fm-ana-crumb { color: var(--accent); text-decoration: none; padding: 2px 3px; border-radius: var(--r-sm); transition: all var(--transition-fast); }
.fm-ana-crumb:hover { background: rgba(79,140,255,.12); }
.fm-ana-summary { padding: 14px; background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: 10px; }
.fm-ana-tabs { display: flex; gap: 4px; margin-bottom: 8px; }
.fm-ana-sub-tab { background: none; border: none; color: var(--text-muted); padding: 6px 14px; cursor: pointer; border-radius: var(--r-sm); font-size: 0.85em; transition: all var(--transition-fast); }
.fm-ana-sub-tab:hover { background: var(--overlay-2); }
.fm-ana-sub-tab.active { background: var(--accent); color: #fff; }
.fm-ana-content { flex: 1; overflow-y: auto; }
.fm-ana-list { display: flex; flex-direction: column; gap: 2px; }
.fm-ana-row { display: flex; align-items: center; gap: 10px; padding: 8px 10px; border-radius: var(--r-sm); cursor: pointer; transition: background var(--transition-fast); }
.fm-ana-row:hover { background: var(--overlay-2); }
.fm-ana-file-row { cursor: default; }
.fm-ana-row-icon { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
.fm-ana-row-info { flex: 1; min-width: 0; }
.fm-ana-row-name { font-size: 13px; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.fm-ana-row-bar { height: 3px; background: var(--overlay-3); border-radius: 2px; margin-top: 4px; overflow: hidden; }
.fm-ana-row-bar-fill { height: 100%; border-radius: 2px; transition: width var(--transition-slow); }
.fm-ana-row-size { font-size: 12px; font-weight: 600; color: var(--text); white-space: nowrap; min-width: 70px; text-align: right; }
.fm-ana-row-pct { font-size: 11px; color: var(--text-muted); white-space: nowrap; min-width: 40px; text-align: right; }

/* ═══ Format Modal ═══ */
.st-format-modal .modal { max-width: 520px; }
.st-fmt-drive-info {
    display: flex; align-items: center; gap: 12px;
    padding: 12px; background: rgba(249,115,22,.06);
    border: 1px solid rgba(249,115,22,.2); border-radius: var(--r-md);
    margin-bottom: 16px;
}
.st-fmt-field { margin-bottom: 14px; }
.st-fmt-fs-list { display: flex; flex-direction: column; gap: 4px; max-height: 260px; overflow-y: auto; }
.st-fmt-fs-option {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 10px 12px; border-radius: var(--r-md); cursor: pointer;
    border: 1px solid var(--border); transition: all var(--transition-fast);
}
.st-fmt-fs-option:hover:not(.disabled) { border-color: var(--accent); background: rgba(79,140,255,.04); }
.st-fmt-fs-option.selected { border-color: var(--accent); background: rgba(79,140,255,.08); }
.st-fmt-fs-option.selected .st-fmt-fs-radio-dot { transform: scale(1); }
.st-fmt-fs-option.disabled { opacity: .4; cursor: not-allowed; }
.st-fmt-fs-radio {
    width: 18px; height: 18px; border-radius: 50%;
    border: 2px solid var(--border); display: flex;
    align-items: center; justify-content: center;
    flex-shrink: 0; margin-top: 2px;
}
.st-fmt-fs-option.selected .st-fmt-fs-radio { border-color: var(--accent); }
.st-fmt-fs-radio-dot {
    width: 10px; height: 10px; border-radius: 50%;
    background: var(--accent); transform: scale(0); transition: transform var(--transition-fast);
}
.st-fmt-fs-info { flex: 1; min-width: 0; }
.st-fmt-fs-label { font-size: 13px; font-weight: 600; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.st-fmt-fs-desc { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.st-fmt-fs-os { display: flex; gap: 6px; margin-top: 4px; font-size: 13px; }
.st-fmt-badge-rec {
    font-size: 10px; font-weight: 600;
    background: rgba(16,185,129,.15); color: #10b981;
    padding: 1px 7px; border-radius: var(--r-md);
    display: inline-flex; align-items: center; gap: 3px;
}
.st-fmt-badge-na {
    font-size: 10px; font-weight: 500;
    background: rgba(239,68,68,.12); color: var(--danger);
    padding: 1px 7px; border-radius: var(--r-md);
}
.st-fmt-system-info {
    display: flex; align-items: center; gap: 8px;
    padding: 10px 12px; background: rgba(79,140,255,.06);
    border-radius: var(--r-md); font-size: 12px;
    color: var(--text-secondary);
}
.st-fmt-progress { display: flex; flex-direction: column; gap: 12px; }
.st-fmt-progress-header { display: flex; align-items: center; gap: 12px; }
.st-fmt-log {
    background: rgba(0,0,0,.25); border-radius: var(--r-md);
    padding: 10px; max-height: 180px; overflow-y: auto;
    font-family: monospace; font-size: 12px;
}
.st-fmt-log-line { display: flex; align-items: flex-start; gap: 6px; padding: 2px 0; }
.st-fmt-log-line span { word-break: break-all; }
.st-fmt-result-ok, .st-fmt-result-err {
    display: flex; align-items: center; gap: 12px;
    padding: 12px; border-radius: var(--r-md); margin-top: 4px;
}
.st-fmt-result-ok { background: rgba(16,185,129,.08); border: 1px solid rgba(16,185,129,.2); }
.st-fmt-result-err { background: rgba(239,68,68,.08); border: 1px solid rgba(239,68,68,.2); }

/* ═══ Split / Partition ═══ */
.st-split-bar {
    display: flex; height: 24px; border-radius: var(--r-sm); overflow: hidden;
    background: var(--overlay-2); margin-bottom: 14px; gap: 1px;
}
.st-split-bar-seg { border-radius: var(--r-sm); transition: width var(--transition-slow); min-width: 4px; }
.st-split-parts { display: flex; flex-direction: column; gap: 8px; max-height: 260px; overflow-y: auto; }
.st-split-part {
    display: flex; gap: 10px; padding: 10px 12px;
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--overlay-1);
}
.st-split-part-num {
    width: 28px; height: 28px; border-radius: 50%;
    background: rgba(6,182,212,.15); color: #06b6d4;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 13px; flex-shrink: 0;
}
.st-split-part-fields { flex: 1; display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.st-split-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.st-split-row label { font-size: 12px; color: var(--text-muted); white-space: nowrap; }
.st-split-row .modal-input { font-size: 13px; padding: 6px 10px; }

/* ═══ Printer App ═══ */
.printer-app { padding: 16px; height: 100%; overflow-y: auto; display: flex; flex-direction: column; gap: 12px; }
.printer-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--border); padding-bottom: 0; margin-bottom: 4px; }
.printer-tab { padding: 10px 20px; border: none; background: none; color: var(--text-muted); font-size: 0.9em; font-weight: 600; cursor: pointer; border-bottom: 2px solid transparent; transition: all var(--transition); border-radius: var(--r-sm) 6px 0 0; }
.printer-tab:hover { color: var(--text); background: var(--overlay-2); }
.printer-tab.active { color: var(--accent); border-bottom-color: var(--accent); background: rgba(79,140,255,0.06); }
.printer-tab-content { display: none; flex-direction: column; gap: 12px; flex: 1; overflow-y: auto; }
.printer-tab-content.active { display: flex; }
.printer-status-bar { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: var(--overlay-2); border-radius: var(--r-md); border: 1px solid var(--border); }
.printer-upload-area { border: 2px dashed var(--border); border-radius: var(--r-lg); padding: 32px; text-align: center; cursor: pointer; transition: all var(--transition); }
.printer-upload-area:hover, .printer-upload-area.dragover { border-color: var(--accent); background: rgba(79,140,255,0.05); }
.printer-selected { display: flex; align-items: center; gap: 10px; padding: 12px; background: rgba(79,140,255,0.08); border-radius: var(--r-md); border: 1px solid var(--accent); }
.printer-settings { display: flex; flex-direction: column; gap: 8px; }
.printer-form-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.printer-form-row label { font-size: 0.85em; color: var(--text-muted); white-space: nowrap; }
.printer-btn { width: 100%; padding: 14px; border: none; border-radius: var(--r-md); background: var(--accent); color: #fff; font-size: 1.05em; font-weight: 600; cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 8px; transition: all var(--transition); }
.printer-btn:hover:not(:disabled) { filter: brightness(1.15); }
.printer-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.printer-result { padding: 12px; border-radius: var(--r-md); font-size: 0.9em; }
.printer-result.success { background: rgba(34, 197, 94, 0.12); border: 1px solid var(--accent-green); color: var(--accent-green); }
.printer-result.error { background: rgba(239, 68, 68, 0.12); border: 1px solid var(--danger); color: var(--danger); }
.printer-job { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 0.9em; }

/* ═══ Printer Manager (manage tab) ═══ */
.pm-section { background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); padding: 14px; }
.pm-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.pm-section-header h3 { font-size: 0.95em; font-weight: 600; display: flex; align-items: center; gap: 8px; margin: 0; }
.pm-list { display: flex; flex-direction: column; gap: 8px; }
.pm-muted { color: var(--text-muted); font-size: 0.85em; margin: 0; }
.pm-card { display: flex; align-items: center; justify-content: space-between; padding: 12px; background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md); gap: 12px; }
.pm-card-main { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }
.pm-card-icon { font-size: 1.4em; width: 36px; text-align: center; flex-shrink: 0; }
.pm-card-info { flex: 1; min-width: 0; }
.pm-card-name { font-weight: 600; font-size: 0.95em; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.pm-card-detail { font-size: 0.8em; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pm-card-actions { display: flex; gap: 4px; flex-shrink: 0; }
.pm-discover-row { display: flex; align-items: center; justify-content: space-between; padding: 10px; background: rgba(79,140,255,0.04); border: 1px solid rgba(79,140,255,0.15); border-radius: var(--r-md); gap: 12px; }
.pm-discover-info { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.pm-discover-info > div { min-width: 0; }
.pm-manual { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.pm-manual.hidden { display: none; }

/* ═══ Resources App ═══ */
.res-app { display: flex; height: 100%; }
.res-sidebar { width: 180px; min-width: 180px; background: rgba(0,0,0,0.2); border-right: 1px solid var(--border); padding: 8px 0; overflow-y: auto; display: flex; flex-direction: column; }
.res-nav { padding: 10px 16px; cursor: pointer; font-size: 0.9em; color: var(--text-muted); transition: all var(--transition-fast); display: flex; align-items: center; gap: 8px; }
.res-nav:hover { color: var(--text); background: var(--overlay-2); }
.res-nav.active { color: var(--text); background: rgba(79,140,255,0.12); border-left: 3px solid var(--accent); }
.res-nav-footer { margin-top: auto; padding: 10px 16px; font-size: 0.8em; color: var(--text-muted); display: flex; align-items: center; gap: 6px; }
.res-main { flex: 1; overflow-y: auto; padding: 16px; }
.res-section { display: none; }
.res-section.active { display: block; }
.res-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.res-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.res-card { background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md); padding: 14px; }
.res-card-hdr { font-size: 0.85em; font-weight: 600; color: var(--text-muted); margin-bottom: 10px; display: flex; align-items: center; gap: 6px; }
.res-card-stats { display: flex; flex-direction: column; gap: 3px; font-size: 0.8em; color: var(--text-muted); margin-top: 8px; }
.res-big-val { font-size: 1.6em; font-weight: 700; margin: 4px 0; }
.res-bar { height: 8px; background: var(--overlay-3); border-radius: var(--r-sm); overflow: hidden; margin: 4px 0; }
.res-bar-fill { height: 100%; border-radius: var(--r-sm); transition: width var(--transition-slow); background: var(--accent); }
.res-info-bar { display: flex; flex-wrap: wrap; gap: 8px 16px; font-size: 0.85em; color: var(--text-muted); padding: 10px 0; }
.res-net-speeds { display: flex; flex-direction: column; gap: 6px; margin: 8px 0; font-size: 1.1em; }
.res-core-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; }
.res-core-item { display: flex; align-items: center; gap: 6px; font-size: 0.85em; }
.res-core-item .res-bar { flex: 1; }
.res-disk-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--overlay-2); font-size: 0.85em; }
.res-disk-mount { font-weight: 500; min-width: 120px; }
.res-disk-row .res-bar { flex: 1; min-width: 100px; }
.res-disk-pct { min-width: 50px; text-align: right; }
.res-proc-table { width: 100%; border-collapse: collapse; font-size: 0.85em; }
.res-proc-table th { text-align: left; font-size: 0.75em; text-transform: uppercase; color: var(--text-muted); padding: 6px 8px; border-bottom: 1px solid var(--border); }
.res-proc-table td { padding: 5px 8px; border-bottom: 1px solid var(--overlay-2); }
.res-proc-table tr:hover td { background: var(--overlay-2); }
.res-proc-controls { display: flex; gap: 10px; margin-bottom: 8px; }
.res-empty { text-align: center; padding: 40px; color: var(--text-muted); }
.res-empty i { font-size: 40px; margin-bottom: 12px; display: block; }

/* ═══ Backup App ═══ */
.bak-app { height: 100%; display: flex; flex-direction: column; overflow: hidden; position: relative; }
.bak-app .fm-toolbar-btn { width: auto; height: auto; padding: 6px 12px; gap: 6px; font-size: 12px; white-space: nowrap; }
.bak-tabs { display: flex; gap: 4px; padding: 8px 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
.bak-tab { background: none; border: none; color: var(--text-muted); padding: 8px 14px; cursor: pointer; border-radius: var(--r-sm); font-size: 0.9em; display: flex; align-items: center; gap: 6px; transition: all var(--transition-fast); }
.bak-tab:hover { background: var(--overlay-2); }
.bak-tab.active { background: var(--accent); color: #fff; }
.bak-status { font-size: 0.72em; color: var(--text-muted); display: flex; align-items: center; gap: 4px; margin-top: 2px; }
.bak-status.active { color: var(--accent); }
.bak-panel { display: none; padding: 16px; overflow-y: auto; flex: 1; }
.bak-panel.active { display: block; }
.bak-panel h3 { font-size: 1em; margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.bak-paths-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 12px; }
.bak-path-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: var(--overlay-2); border-radius: var(--r-sm); font-size: 0.9em; }
.bak-path-item button { margin-left: auto; flex-shrink: 0; }
.bak-path-add { display: flex; gap: 8px; align-items: center; }
.bak-dest-select { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.bak-dest-select h4 { font-size: 0.9em; margin-right: 4px; }
.bak-progress { margin-top: 16px; padding: 14px; background: var(--overlay-2); border-radius: var(--r-md); border: 1px solid var(--border); }
.bak-progress-text { font-size: 0.85em; color: var(--text-muted); margin-bottom: 6px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-progress-info { font-size: 0.8em; color: var(--text-muted); margin-top: 4px; }
.bak-backup-item, .bak-profile-item, .bak-history-item, .bak-usb-item, .bak-ssh-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--overlay-2); border-radius: var(--r-sm); margin-bottom: 4px; font-size: 0.9em; flex-wrap: wrap; }
.bak-profile-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.bak-hist-completed i { color: var(--accent-green); }
.bak-hist-failed i { color: var(--danger); }
.bak-hist-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.bak-modal { position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 1200; display: flex; align-items: center; justify-content: center; }
#bak-browser-modal { z-index: 1210; }
.bak-modal-content { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); width: 500px; max-width: 95%; max-height: 80%; display: flex; flex-direction: column; }
.bak-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.bak-modal-footer { padding: 10px 16px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; }
.bak-browser-breadcrumbs { padding: 8px 16px; display: flex; align-items: center; gap: 2px; flex-wrap: wrap; border-bottom: 1px solid var(--border); font-size: 0.85em; }
.bak-crumb { color: var(--accent); cursor: pointer; padding: 2px 5px; border-radius: var(--r-sm); transition: background var(--transition-fast); }
.bak-crumb:hover { background: rgba(79,140,255,0.12); }
.bak-crumb-active { color: var(--text); cursor: default; font-weight: 600; }
.bak-crumb-active:hover { background: none; }
.bak-crumb-sep { color: var(--text-muted); font-size: 0.85em; padding: 0 1px; }
.bak-browser-toolbar { display: flex; align-items: center; gap: 6px; padding: 8px 16px; border-bottom: 1px solid var(--border); background: var(--overlay-1); }
.bak-browser-list { flex: 1; overflow-y: auto; max-height: 350px; }
.bak-browser-item { padding: 9px 16px; cursor: pointer; display: flex; align-items: center; gap: 10px; font-size: 0.9em; transition: background var(--transition-fast); border-bottom: 1px solid var(--overlay-2); }
.bak-browser-item:hover { background: rgba(79,140,255,0.08); }
.bak-browser-item:last-child { border-bottom: none; }
.bak-browser-item-up { color: var(--text-muted); font-style: italic; }
.bak-browser-item-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-browser-selected { padding: 8px 16px; font-size: 0.85em; color: var(--text-muted); border-top: 1px solid var(--border); display: flex; align-items: center; gap: 8px; background: rgba(79,140,255,0.04); }
.bak-browser-selected strong { color: var(--text); }
.bak-dest-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.bak-dest-path-display { display: flex; align-items: center; gap: 8px; margin-top: 8px; padding: 8px 12px; background: rgba(79,140,255,0.12); border: 1px solid rgba(79,140,255,0.3); border-radius: var(--r-sm); font-size: 0.88em; font-family: monospace; overflow: hidden; }
.bak-dest-path-display span { flex: 1; min-width: 0; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-ssh-form, .bak-profile-form { padding: 16px; background: var(--overlay-1); border-radius: var(--r-md); margin-top: 12px; border: 1px solid var(--border); }
.bak-ssh-form h4, .bak-profile-form h4 { margin-bottom: 12px; }

/* ── Backup badges ── */
.bak-badge { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: var(--r-sm); font-size: 0.8em; background: var(--overlay-3); color: var(--text-muted); white-space: nowrap; }
.bak-badge-blue { background: rgba(59,130,246,0.15); color: #60a5fa; }
.bak-badge-green { background: rgba(16,185,129,0.15); color: #34d399; }
.bak-badge-purple { background: rgba(168,85,247,0.15); color: #c084fc; }
.bak-badge-orange { background: rgba(251,146,60,0.15); color: #fb923c; }
.bak-badge i { font-size: 0.85em; }

/* ── Empty states ── */
.bak-empty-state { text-align: center; padding: 32px 16px; color: var(--text-muted); }
.bak-empty-state i { font-size: 2.5em; margin-bottom: 10px; display: block; opacity: 0.3; }
.bak-empty-state p { font-size: 1em; font-weight: 600; margin: 0 0 4px; }
.bak-empty-state span { font-size: 0.85em; opacity: 0.7; }
.bak-empty-sm { padding: 20px 12px; }
.bak-empty-sm i { font-size: 1.8em; margin-bottom: 6px; }
.bak-empty-sm p { font-size: 0.9em; }

/* ── Path display ── */
.bak-path-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.bak-path-pretty { font-size: 0.9em; font-family: monospace; font-weight: 600; color: var(--text); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-path-raw { font-size: 0.72em; color: var(--text-muted); font-family: monospace; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-path-dir { color: var(--text-muted); font-family: monospace; font-size: 0.9em; }
.bak-path-name { color: var(--text); font-family: monospace; font-size: 0.9em; font-weight: 600; }
.bak-path-text { flex: 1; min-width: 0; font-size: 0.9em; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bak-path-pill { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; background: rgba(79,140,255,0.08); border: 1px solid rgba(79,140,255,0.15); border-radius: var(--r-sm); font-size: 0.82em; font-family: monospace; color: var(--text); margin: 2px 4px 2px 0; white-space: nowrap; }
.bak-path-pill i { color: var(--accent); font-size: 0.9em; flex-shrink: 0; }

/* ── Profile cards (improved) ── */
.bak-section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; gap: 8px; flex-wrap: wrap; }
.bak-section-header h3 { margin-bottom: 0; white-space: nowrap; }
.bak-section-header .fm-toolbar-btn { width: auto; height: auto; padding: 6px 12px; gap: 6px; white-space: nowrap; font-size: 0.82em; }
.bak-profile-card { background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md); padding: 0; margin-bottom: 10px; overflow: hidden; transition: border-color var(--transition-fast); }
.bak-profile-card:hover { border-color: rgba(79,140,255,0.3); }
.bak-profile-card-header { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px 10px; }
.bak-profile-icon { width: 36px; height: 36px; border-radius: var(--r-md); background: rgba(79,140,255,0.12); display: flex; align-items: center; justify-content: center; color: var(--accent); font-size: 1em; flex-shrink: 0; }
.bak-profile-title { flex: 1; min-width: 0; }
.bak-profile-title strong { display: block; font-size: 1em; margin-bottom: 6px; }
.bak-profile-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.bak-profile-card-body { padding: 0 16px 12px; display: flex; flex-direction: column; gap: 8px; }
.bak-profile-row { display: flex; align-items: flex-start; gap: 8px; }
.bak-profile-info-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.bak-profile-label { font-size: 0.8em; color: var(--text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.03em; display: flex; align-items: center; gap: 5px; white-space: nowrap; min-width: 60px; padding-top: 4px; }
.bak-profile-label i { font-size: 0.9em; }
.bak-profile-paths { display: flex; flex-wrap: wrap; gap: 4px; flex: 1; min-width: 0; }
.bak-profile-dest-detail { font-size: 0.88em; color: var(--text); font-family: monospace; display: flex; align-items: center; gap: 5px; padding: 4px 10px; background: rgba(16,185,129,0.06); border: 1px solid rgba(16,185,129,0.15); border-radius: var(--r-sm); }
.bak-profile-dest-detail i { color: #34d399; font-size: 0.9em; }
.bak-profile-dest-detail strong { color: var(--text); }
.bak-profile-detail { font-size: 0.85em; color: var(--text-muted); display: flex; align-items: center; gap: 5px; }
.bak-profile-detail i { font-size: 0.85em; }
.bak-profile-detail strong { color: var(--text); }
.bak-profile-card-meta { display: flex; gap: 16px; font-size: 0.85em; color: var(--text-muted); margin-bottom: 10px; flex-wrap: wrap; padding: 0 16px; }
.bak-profile-card-meta span { display: flex; align-items: center; gap: 5px; }
.bak-profile-card-actions { display: flex; gap: 6px; padding: 10px 16px; border-top: 1px solid var(--border); background: var(--overlay-1); }
.bak-profile-card-actions .fm-toolbar-btn { width: auto; height: auto; padding: 6px 14px; gap: 6px; white-space: nowrap; }
.btn-sm { padding: 4px 10px !important; font-size: 0.82em !important; }

/* ── Backup group headers ── */
.bak-group { margin-bottom: 10px; border: 1px solid var(--border); border-radius: var(--r-md); overflow: hidden; background: var(--overlay-1); }
.bak-group-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; cursor: pointer; user-select: none; transition: background var(--transition-fast); }
.bak-group-header:hover { background: var(--overlay-2); }
.bak-group-header-left { display: flex; align-items: center; gap: 10px; font-size: 0.95em; }
.bak-group-header-right { display: flex; align-items: center; gap: 8px; }
.bak-group-chevron { font-size: 0.75em; color: var(--text-muted); transition: transform var(--transition), box-shadow var(--transition); }
.bak-group-collapsed .bak-group-chevron { transform: rotate(-90deg); }
.bak-group-body { padding: 0 10px 10px; }
.bak-group-collapsed .bak-group-body { display: none; }
.bak-group-body .bak-backup-card:last-child { margin-bottom: 0; }

/* ── Backup list cards ── */
.bak-backup-card { display: flex; align-items: center; gap: 12px; padding: 12px 14px; background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: 6px; transition: border-color var(--transition-fast); flex-wrap: wrap; }
.bak-backup-card:hover { border-color: rgba(79,140,255,0.3); }
.bak-backup-card-left { display: flex; align-items: center; gap: 12px; flex: 1 1 0; min-width: 0; overflow: hidden; }
.bak-backup-icon { width: 38px; height: 38px; border-radius: var(--r-md); display: flex; align-items: center; justify-content: center; font-size: 1em; flex-shrink: 0; }
.bak-icon-green { background: rgba(16,185,129,0.12); color: #34d399; }
.bak-icon-purple { background: rgba(168,85,247,0.12); color: #c084fc; }
.bak-icon-orange { background: rgba(251,146,60,0.12); color: #fb923c; }
.bak-backup-info { flex: 1; min-width: 0; overflow: hidden; }
.bak-backup-name { display: block; font-size: 0.88em; font-family: monospace; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 4px; }
.bak-backup-meta { display: flex; gap: 6px 12px; flex-wrap: wrap; font-size: 0.8em; color: var(--text-muted); align-items: center; }
.bak-backup-meta span { display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.bak-backup-meta .bak-badge { max-width: 260px; overflow: hidden; text-overflow: ellipsis; }
.bak-backup-meta i { font-size: 0.85em; }
.bak-backup-card-actions { display: flex; gap: 4px; flex-shrink: 0; margin-left: auto; }

/* ── History cards ── */
.bak-history-card { display: flex; align-items: flex-start; gap: 12px; padding: 12px 14px; background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md); margin-bottom: 6px; }
.bak-hist-status-icon { width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1em; flex-shrink: 0; }
.bak-hist-completed .bak-hist-status-icon { background: rgba(16,185,129,0.12); color: #34d399; }
.bak-hist-failed .bak-hist-status-icon { background: rgba(239, 68, 68, 0.12); color: var(--danger); }
.bak-hist-content { flex: 1; min-width: 0; }
.bak-hist-title { font-weight: 600; font-size: 0.9em; font-family: monospace; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; margin-bottom: 6px; }
.bak-hist-details { display: flex; gap: 12px; flex-wrap: wrap; font-size: 0.8em; color: var(--text-muted); }
.bak-hist-details span { display: flex; align-items: center; gap: 4px; white-space: nowrap; }
.bak-hist-details i { font-size: 0.85em; }
.bak-hist-dest { margin-top: 6px; font-size: 0.82em; color: var(--accent); display: flex; align-items: center; gap: 5px; }
.bak-hist-dest i { font-size: 0.8em; }
.bak-hist-dest strong { font-family: monospace; }
.bak-hist-error { margin-top: 6px; font-size: 0.82em; color: var(--danger); display: flex; align-items: center; gap: 5px; padding: 4px 8px; background: rgba(239, 68, 68, 0.08); border-radius: var(--r-sm); }

/* ── Progress enhancements ── */
.bak-progress-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
.bak-log-details { margin-top: 10px; }
.bak-log-details summary { cursor: pointer; font-size: 0.85em; color: var(--text-muted); display: flex; align-items: center; gap: 6px; }
.bak-log-viewer { max-height: 180px; overflow-y: auto; background: rgba(0,0,0,0.3); border-radius: var(--r-sm); padding: 8px 10px; margin-top: 6px; font-family: monospace; font-size: 0.78em; line-height: 1.5; }
.bak-log-line { color: #94a3b8; white-space: pre-wrap; word-break: break-all; }

/* ── Preview modal ── */
.bak-preview-header { margin-bottom: 14px; }
.bak-preview-section { margin-bottom: 16px; }
.bak-preview-section h5 { font-size: 0.9em; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; }
.bak-chain-list { display: flex; flex-direction: column; gap: 3px; }
.bak-chain-item { display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: var(--overlay-2); border-radius: var(--r-sm); font-size: 0.85em; }
.bak-chain-current { background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.3); }
.bak-chain-num { width: 22px; height: 22px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.75em; font-weight: 600; flex-shrink: 0; }
.bak-dir-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 4px; }
.bak-dir-item { display: flex; align-items: center; gap: 6px; padding: 4px 8px; font-size: 0.85em; }
.bak-file-list { max-height: 200px; overflow-y: auto; background: rgba(0,0,0,0.2); border-radius: var(--r-sm); padding: 6px 10px; }
.bak-file-item { display: flex; align-items: center; gap: 6px; padding: 2px 0; font-size: 0.82em; font-family: monospace; }

/* ── Day picker chips ── */
.bak-day-chip { display: inline-flex; align-items: center; gap: 3px; padding: 4px 8px; border-radius: var(--r-sm); font-size: 0.85em; background: var(--overlay-2); cursor: pointer; }
.bak-day-chip:has(input:checked) { background: var(--accent); color: #fff; }
.bak-day-chip input { display: none; }

/* ── Scheduled backup items ── */
.bak-scheduled-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; background: var(--overlay-2); border-radius: var(--r-sm); margin-bottom: 4px; font-size: 0.9em; flex-wrap: wrap; }

/* ── PM paths ── */
.bak-pm-paths { display: flex; flex-direction: column; gap: 3px; }

/* ═══════════════════════════════════════════════════════════
   Terminal App
   ═══════════════════════════════════════════════════════════ */

.term-app {
    display: flex; flex-direction: column;
    height: 100%; background: #0d1117; overflow: hidden;
}

/* ── Login screen ── */
.term-login {
    display: flex; align-items: center; justify-content: center;
    height: 100%; padding: 32px;
    background: linear-gradient(135deg, #0d1117 0%, #161b22 100%);
}

.term-login-card {
    text-align: center; max-width: 420px; width: 100%;
}

.term-login-icon {
    width: 72px; height: 72px; margin: 0 auto 20px;
    border-radius: 20px; display: flex; align-items: center; justify-content: center;
    background: rgba(34,197,94,0.12); color: var(--success); font-size: 32px;
}

.term-login-card h3 {
    color: #f0f6fc; font-size: 20px; font-weight: 600; margin: 0 0 6px;
}

.term-login-sub {
    color: #8b949e; font-size: 13px; margin: 0 0 24px;
}

.term-user-list {
    display: flex; flex-direction: column; gap: 6px;
    max-height: 320px; overflow-y: auto;
    padding-right: 4px;
}

.term-user-list::-webkit-scrollbar { width: 4px; }
.term-user-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 2px; }

.term-user-btn {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px; border-radius: var(--r-md);
    background: var(--overlay-2); border: 1px solid var(--overlay-3);
    color: #c9d1d9; cursor: pointer; transition: all var(--transition-fast);
    text-align: left; width: 100%;
}

.term-user-btn:hover {
    background: rgba(34,197,94,0.08); border-color: rgba(34,197,94,0.3);
    color: #f0f6fc;
}

.term-user-avatar {
    width: 36px; height: 36px; border-radius: var(--r-md);
    background: var(--overlay-3); display: flex;
    align-items: center; justify-content: center; flex-shrink: 0;
    color: #8b949e; font-size: 14px;
}

.term-user-btn:hover .term-user-avatar { color: var(--success); background: rgba(34,197,94,0.12); }

.term-user-info { flex: 1; min-width: 0; }

.term-user-name {
    display: block; font-size: 14px; font-weight: 500; color: inherit;
}

.term-user-detail {
    display: block; font-size: 11px; color: #8b949e; margin-top: 2px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.term-user-arrow { color: #484f58; font-size: 11px; flex-shrink: 0; }
.term-user-btn:hover .term-user-arrow { color: var(--success); }

.term-loading, .term-no-users {
    color: #8b949e; font-size: 13px; padding: 20px; text-align: center;
}

/* ── Terminal container ── */
.term-container {
    display: flex; flex-direction: column; height: 100%;
}

.term-topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 12px; background: #161b22;
    border-bottom: 1px solid var(--overlay-3);
    flex-shrink: 0;
}

.term-topbar-info {
    display: flex; align-items: center; gap: 8px;
    font-size: 12px; color: #8b949e;
}

.term-topbar-info i { color: var(--success); font-size: 11px; }

.term-topbar-actions { display: flex; gap: 4px; }

.term-topbar-btn {
    background: none; border: none; color: #8b949e; cursor: pointer;
    padding: 4px 8px; border-radius: var(--r-sm); font-size: 12px;
    transition: all var(--transition-fast);
}

.term-topbar-btn:hover { background: var(--overlay-3); color: #f0f6fc; }

.term-xterm {
    flex: 1; overflow: hidden; padding: 4px;
}

.term-xterm .xterm { height: 100%; }
.term-xterm .xterm-viewport::-webkit-scrollbar { width: 6px; }
.term-xterm .xterm-viewport::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: var(--r-sm); }


/* ═══════════════════════════════════════════════════════════
   Package Manager (App Store)
   ═══════════════════════════════════════════════════════════ */

.pkg-app {
    display: flex; height: 100%; background: var(--bg-primary); overflow: hidden;
}

/* ── Sidebar ── */
.pkg-sidebar {
    width: 200px; min-width: 200px; background: var(--bg-surface);
    border-right: 1px solid var(--border); display: flex;
    flex-direction: column; flex-shrink: 0;
}

.pkg-sidebar-logo {
    display: flex; align-items: center; gap: 10px;
    padding: 18px 16px; font-weight: 600; font-size: 15px;
    color: var(--text-primary); border-bottom: 1px solid var(--border);
}

.pkg-sidebar-logo i { color: var(--accent-purple); font-size: 18px; }

.pkg-nav { display: flex; flex-direction: column; padding: 8px; gap: 2px; }

.pkg-nav-btn {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 12px; border-radius: var(--r-md); border: none;
    background: none; color: var(--text-secondary); cursor: pointer;
    font-size: 13px; text-align: left; transition: all var(--transition-fast);
    position: relative;
}

.pkg-nav-btn:hover { background: var(--overlay-2); color: var(--text-primary); }

.pkg-nav-btn.active {
    background: rgba(168,85,247,0.1); color: var(--accent-purple); font-weight: 500;
}

.pkg-nav-btn i { width: 16px; text-align: center; font-size: 13px; }

.pkg-badge {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 18px; height: 18px; padding: 0 5px;
    border-radius: var(--r-md); font-size: 10px; font-weight: 700;
    background: var(--danger); color: #fff; margin-left: auto;
}

/* ── Main content ── */
.pkg-main { flex: 1; overflow-y: auto; }

.pkg-tab { display: none; padding: 24px; }
.pkg-tab.active { display: block; }

.pkg-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 20px; gap: 16px; flex-wrap: wrap;
}

.pkg-header h2 { font-size: 18px; font-weight: 600; color: var(--text-primary); margin: 0; }

.pkg-header-actions { display: flex; align-items: center; gap: 8px; }

/* ── Overview stat cards ── */
.pkg-overview-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px; margin-bottom: 20px;
}

.pkg-stat-card {
    display: flex; align-items: center; gap: 14px;
    padding: 16px; border-radius: var(--r-lg);
    background: var(--bg-surface); border: 1px solid var(--border);
}

.pkg-stat-icon {
    width: 44px; height: 44px; border-radius: var(--r-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 18px; flex-shrink: 0;
}

.pkg-stat-info { display: flex; flex-direction: column; }

.pkg-stat-val { font-size: 18px; font-weight: 700; color: var(--text-primary); line-height: 1.2; }

.pkg-stat-label { font-size: 11px; color: var(--text-muted); margin-top: 2px; }

/* ── Action buttons row ── */
.pkg-actions-row {
    display: flex; gap: 10px; margin-bottom: 20px; flex-wrap: wrap;
}

.pkg-action-btn {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px; border-radius: var(--r-md);
    background: var(--bg-surface); border: 1px solid var(--border);
    color: var(--text-primary); cursor: pointer;
    transition: all var(--transition-fast); flex: 1; min-width: 180px;
}

.pkg-action-btn:hover {
    border-color: rgba(168,85,247,0.4); background: rgba(168,85,247,0.06);
}

.pkg-action-btn i { font-size: 20px; color: var(--accent-purple); width: 24px; text-align: center; }

.pkg-action-btn div { display: flex; flex-direction: column; }
.pkg-action-btn strong { font-size: 13px; font-weight: 600; }
.pkg-action-btn small { font-size: 11px; color: var(--text-muted); margin-top: 2px; }
.pkg-action-btn.small { padding: 8px 14px; }

/* ── dpkg warning ── */
.pkg-dpkg-warn {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 18px; margin-bottom: 16px;
    background: rgba(245,158,11,0.1); border: 1px solid rgba(245,158,11,0.3);
    border-radius: var(--r-md); color: #f59e0b; font-size: 13px;
}
.pkg-dpkg-warn i { font-size: 18px; flex-shrink: 0; }
.pkg-dpkg-warn span { flex: 1; }

/* ── Output terminal ── */
.pkg-output-wrap {
    border-radius: var(--r-md); overflow: hidden;
    border: 1px solid var(--border); background: #0d1117;
}

.pkg-output-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 14px; background: var(--overlay-2);
    border-bottom: 1px solid var(--overlay-3);
    font-size: 12px; color: var(--text-secondary);
}

.pkg-output-close {
    background: none; border: none; color: var(--text-muted);
    cursor: pointer; padding: 2px 6px; border-radius: var(--r-sm);
}
.pkg-output-close:hover { background: var(--overlay-3); color: var(--text-primary); }

.pkg-output {
    padding: 12px 14px; margin: 0; max-height: 300px; overflow-y: auto;
    font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 12px; line-height: 1.6; color: #c9d1d9;
    white-space: pre-wrap; word-break: break-all;
}

.pkg-output::-webkit-scrollbar { width: 5px; }
.pkg-output::-webkit-scrollbar-thumb { background: var(--overlay-4); border-radius: var(--r-sm); }

/* ── Search box ── */
.pkg-search-box {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 12px; border-radius: var(--r-md);
    background: var(--bg-primary); border: 1px solid var(--border);
    transition: border-color var(--transition-fast);
}

.pkg-search-box:focus-within { border-color: var(--accent-purple); }
.pkg-search-box i { color: var(--text-muted); font-size: 12px; }

.pkg-search-box input {
    background: none; border: none; outline: none;
    color: var(--text-primary); font-size: 13px; width: 160px;
}
.pkg-search-box.large input { width: 260px; }

/* ── Package list ── */
.pkg-list {
    display: flex; flex-direction: column; gap: 4px;
}

.pkg-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px; border-radius: var(--r-md);
    background: var(--bg-surface); border: 1px solid transparent;
    transition: all var(--transition-fast);
}

.pkg-item:hover { border-color: var(--border); }

.pkg-item-icon {
    width: 36px; height: 36px; border-radius: var(--r-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 14px; flex-shrink: 0;
}

.pkg-item-icon.upd { background: rgba(245,158,11,0.12); color: #f59e0b; }
.pkg-item-icon.inst { background: rgba(59,130,246,0.12); color: #3b82f6; }
.pkg-item-icon.avail { background: rgba(168,85,247,0.12); color: var(--accent-purple); }

.pkg-item-info { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.pkg-item-name {
    font-size: 13px; font-weight: 600; color: var(--text-primary);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.pkg-item-meta {
    font-size: 11px; color: var(--text-muted); margin-top: 1px;
}

.pkg-item-desc {
    font-size: 11px; color: var(--text-secondary); margin-top: 2px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

.pkg-item-btn {
    width: 32px; height: 32px; border-radius: var(--r-sm); border: none;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; font-size: 12px; transition: all var(--transition-fast);
    flex-shrink: 0;
}

.pkg-item-btn.install {
    background: rgba(34,197,94,0.1); color: var(--success);
}
.pkg-item-btn.install:hover { background: rgba(34,197,94,0.25); }

.pkg-item-btn.remove {
    background: rgba(239,68,68,0.08); color: var(--danger);
}
.pkg-item-btn.remove:hover { background: rgba(239,68,68,0.2); }

.pkg-loading, .pkg-empty {
    display: flex; align-items: center; justify-content: center;
    gap: 10px; padding: 40px; color: var(--text-muted); font-size: 14px;
}

.pkg-empty i { font-size: 20px; }

.pkg-list-more {
    text-align: center; padding: 12px; color: var(--text-muted);
    font-size: 12px; font-style: italic;
}

.pkg-list-status {
    padding: 8px 0; font-size: 11px; color: var(--text-muted); text-align: right;
}


/* ═══ Responsive ═══ */
@media (max-width: 900px) {
    .res-grid-4 { grid-template-columns: repeat(2, 1fr); }
    .res-sidebar { width: 50px; min-width: 50px; }
    .res-nav span { display: none; }
}


/* ═══════════════════════════════════════════════════════════════
   Users & Groups Management
   ═══════════════════════════════════════════════════════════════ */

.usr-app {
    display: flex; height: 100%; background: var(--bg-primary);
    font-family: 'Inter', sans-serif;
}

/* ─── Sidebar ─── */
.usr-sidebar {
    width: 200px; min-width: 200px; background: var(--bg-secondary);
    border-right: 1px solid var(--border); display: flex; flex-direction: column;
    padding: 16px 0;
}
.usr-sidebar-logo {
    display: flex; align-items: center; gap: 10px; padding: 0 20px 20px;
    font-size: 15px; font-weight: 600; color: var(--text);
    border-bottom: 1px solid var(--border);
}
.usr-sidebar-logo i { font-size: 20px; color: #ec4899; }
.usr-nav { display: flex; flex-direction: column; padding: 12px 8px; gap: 2px; }
.usr-nav-btn {
    display: flex; align-items: center; gap: 10px; padding: 10px 14px;
    border: none; background: transparent; color: var(--text-muted);
    cursor: pointer; border-radius: var(--r-md); font-size: 13px; text-align: left;
    transition: all var(--transition-fast);
}
.usr-nav-btn:hover { background: var(--bg-hover); color: var(--text); }
.usr-nav-btn.active { background: rgba(236,72,153,0.12); color: #ec4899; font-weight: 600; }
.usr-nav-btn i { width: 18px; text-align: center; }

/* ─── Main area ─── */
.usr-main { flex: 1; overflow-y: auto; padding: 24px; }
.usr-tab { display: none; }
.usr-tab.active { display: block; }
.usr-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 10px; }
.usr-header h2 { font-size: 20px; font-weight: 700; color: var(--text); margin: 0; }
.usr-header-sub { font-size: 13px; color: var(--text-muted); margin: 4px 0 0; }
.usr-header-actions { display: flex; gap: 8px; }

/* ─── Buttons ─── */
.usr-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 8px 16px; border-radius: var(--r-md); border: none;
    font-size: 13px; font-weight: 500; cursor: pointer; transition: all var(--transition-fast);
}
.usr-btn.primary { background: #ec4899; color: #fff; }
.usr-btn.primary:hover { background: #db2777; }
.usr-btn.secondary { background: var(--bg-tertiary); color: var(--text); }
.usr-btn.secondary:hover { background: var(--bg-hover); }

.usr-icon-btn {
    width: 34px; height: 34px; border-radius: var(--r-md); border: none;
    background: var(--bg-tertiary); color: var(--text-muted); cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: all var(--transition-fast); font-size: 13px;
}
.usr-icon-btn:hover { background: var(--bg-hover); color: var(--text); }
.usr-icon-btn.danger:hover { background: rgba(239,68,68,0.15); color: var(--danger); }

/* ─── Lists / Cards ─── */
.usr-list { display: flex; flex-direction: column; gap: 8px; }
.usr-card {
    display: flex; align-items: center; gap: 16px;
    padding: 14px 18px; background: var(--bg-secondary);
    border: 1px solid var(--border); border-radius: var(--r-lg);
    transition: border-color var(--transition-fast);
}
.usr-card:hover { border-color: var(--border-hover); }

.usr-card-avatar {
    width: 48px; height: 48px; border-radius: var(--r-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; flex-shrink: 0;
    background: rgba(100,116,139,0.1); color: #64748b;
}
.usr-card-avatar.admin { background: rgba(236,72,153,0.12); color: #ec4899; }
.usr-card-avatar.group { background: rgba(59,130,246,0.12); color: #3b82f6; }

.usr-card-info { flex: 1; min-width: 0; }
.usr-card-name {
    font-size: 14px; font-weight: 600; color: var(--text);
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.usr-card-detail {
    display: flex; gap: 16px; margin-top: 4px;
    font-size: 12px; color: var(--text-muted);
}
.usr-card-groups, .usr-card-members {
    margin-top: 6px; display: flex; flex-wrap: wrap; gap: 4px;
    align-items: center;
}

/* ─── Quota bar on user cards ─── */
.usr-quota { margin-top: 6px; display: flex; align-items: center; gap: 8px; }
.usr-quota-bar { flex: 0 0 120px; height: 6px; background: var(--bg-tertiary); border-radius: 3px; overflow: hidden; }
.usr-quota-fill { height: 100%; border-radius: 3px; transition: width 0.3s; }
.usr-quota-text { font-size: 11px; color: var(--text-muted); }
.usr-card-privs {
    margin-top: 4px; display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
}

.usr-card-actions { display: flex; gap: 6px; flex-shrink: 0; }

/* ─── Tags / Badges ─── */
.usr-badge {
    font-size: 10px; font-weight: 600; padding: 2px 8px;
    border-radius: var(--r-md); text-transform: uppercase; letter-spacing: 0.5px;
}
.usr-badge.admin { background: rgba(236,72,153,0.12); color: #ec4899; }
.usr-badge.user { background: rgba(100,116,139,0.1); color: #64748b; }
.usr-badge.priv { background: rgba(245,158,11,0.12); color: #f59e0b; }
.usr-badge.nasos { background: rgba(56,189,248,0.12); color: #38bdf8; }

.usr-group-tag {
    font-size: 11px; padding: 2px 8px; border-radius: var(--r-sm);
    background: rgba(59,130,246,0.1); color: #3b82f6;
}
.usr-app-tag {
    font-size: 11px; padding: 2px 8px; border-radius: var(--r-sm);
    background: rgba(168,85,247,0.1); color: var(--accent-purple);
}
.usr-muted { color: var(--text-muted); font-size: 12px; }

/* ─── Form elements in modals ─── */
.usr-form { display: flex; flex-direction: column; gap: 8px; min-width: 300px; }
.usr-form label { font-size: 12px; font-weight: 600; color: var(--text-muted); margin-top: 4px; }
.usr-input {
    width: 100%; padding: 10px 12px; border-radius: var(--r-md);
    border: 1px solid var(--border); background: var(--bg-primary);
    color: var(--text); font-size: 13px; outline: none;
    transition: border-color var(--transition-fast); box-sizing: border-box;
}
.usr-input:focus { border-color: #ec4899; }
.usr-checkbox-label {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; color: var(--text); cursor: pointer;
    padding: 4px 0;
}
.usr-checkbox-label input[type="checkbox"] { accent-color: #ec4899; }
.usr-group-checkboxes {
    max-height: 250px; overflow-y: auto; display: flex;
    flex-direction: column; gap: 2px; padding: 4px 0;
}

/* ─── Privileges Table ─── */
.usr-priv-table {
    width: 100%; border-collapse: collapse; font-size: 13px;
    background: var(--bg-secondary); border-radius: var(--r-lg);
    overflow: hidden; border: 1px solid var(--border);
}
.usr-priv-table thead { background: var(--bg-tertiary); }
.usr-priv-table th {
    padding: 12px 8px; font-size: 11px; font-weight: 600;
    color: var(--text-muted); text-align: center;
    border-bottom: 1px solid var(--border);
}
.usr-priv-table th:first-child { text-align: left; padding-left: 16px; }
.usr-priv-table td { padding: 10px 8px; text-align: center; border-bottom: 1px solid var(--border); }
.usr-priv-table td:first-child { text-align: left; padding-left: 16px; }
.usr-priv-table tbody tr:hover { background: var(--bg-hover); }
.usr-priv-table input[type="checkbox"] { accent-color: #ec4899; width: 16px; height: 16px; cursor: pointer; }
.usr-priv-group-col { min-width: 130px; }
.usr-priv-app-col { min-width: 60px; }
.usr-priv-group-name { font-weight: 600; color: var(--text); white-space: nowrap; }
.usr-priv-cell { text-align: center; }

.usr-priv-actions {
    display: flex; justify-content: flex-end; margin-top: 16px; gap: 8px;
}

/* ─── States ─── */
.usr-loading, .usr-empty, .usr-error {
    padding: 40px; text-align: center; color: var(--text-muted); font-size: 14px;
}
.usr-error { color: var(--danger); }
.usr-loading i { margin-right: 8px; }

/* ─── LDAP / AD Tab ─── */
.usr-ldap-not-installed {
    display: flex; flex-direction: column; align-items: center; gap: 12px;
    padding: 60px 20px; text-align: center; color: var(--text-muted);
}
.usr-ldap-not-installed h3 { color: var(--text); margin: 0; }
.usr-ldap-not-installed p { max-width: 400px; }
.usr-ldap-form { padding: 16px; display: flex; flex-direction: column; gap: 20px; }
.usr-ldap-toggle-row { display: flex; align-items: center; gap: 12px; padding: 12px 16px; background: var(--bg-secondary); border-radius: 8px; }
.usr-ldap-toggle-label { font-weight: 600; font-size: 15px; }
.usr-ldap-status { margin-left: auto; }
.usr-ldap-toggle { position: relative; width: 40px; height: 22px; flex-shrink: 0; }
.usr-ldap-toggle input { opacity: 0; width: 0; height: 0; }
.usr-toggle-slider {
    position: absolute; inset: 0; background: var(--bg-tertiary); border-radius: 22px;
    cursor: pointer; transition: background .2s;
}
.usr-toggle-slider::before {
    content: ''; position: absolute; left: 3px; top: 3px; width: 16px; height: 16px;
    background: #fff; border-radius: 50%; transition: transform .2s;
}
.usr-ldap-toggle input:checked + .usr-toggle-slider { background: var(--accent); }
.usr-ldap-toggle input:checked + .usr-toggle-slider::before { transform: translateX(18px); }
.usr-ldap-section { background: var(--bg-secondary); border-radius: 8px; padding: 16px; }
.usr-ldap-section h4 { margin: 0 0 12px 0; font-size: 14px; color: var(--text-muted); display: flex; align-items: center; gap: 8px; }
.usr-ldap-grid { display: grid; grid-template-columns: 160px 1fr; gap: 10px 16px; align-items: center; }
.usr-ldap-grid label { font-size: 13px; color: var(--text-muted); }
.usr-ldap-grid .fm-input { width: 100%; }
.usr-ldap-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.usr-ldap-test-result { padding: 12px 16px; background: var(--bg-secondary); border-radius: 8px; font-size: 13px; }
.usr-badge-ok { color: var(--success); font-weight: 600; font-size: 13px; display: inline-flex; align-items: center; gap: 4px; }
.usr-badge-off { color: var(--text-muted); font-weight: 600; font-size: 13px; display: inline-flex; align-items: center; gap: 4px; }

/* ─── Responsive ─── */
@media (max-width: 900px) {
    .usr-sidebar { width: 50px; min-width: 50px; }
    .usr-sidebar-logo span, .usr-nav-btn span { display: none; }
    .usr-card { flex-direction: column; align-items: flex-start; }
    .usr-priv-table { font-size: 11px; }
}

/* ═══════════════════════════════════════════════════════════
   Network Manager (net-)
   ═══════════════════════════════════════════════════════════ */
.net-app { display:flex; height:100%; background:#0b1120; color:#e2e8f0; font-family:'Segoe UI',sans-serif; }

/* ─── Sidebar ─── */
.net-sidebar { width:200px; min-width:200px; background:#111827; border-right:1px solid #1e293b; display:flex; flex-direction:column; }
.net-sidebar-logo { display:flex; align-items:center; gap:10px; padding:18px 16px 14px; font-size:15px; font-weight:700; color:#0ea5e9; border-bottom:1px solid #1e293b; }
.net-sidebar-logo i { font-size:18px; }
.net-nav { display:flex; flex-direction:column; padding:8px 6px; gap:2px; }
.net-nav-btn { display:flex; align-items:center; gap:10px; padding:10px 12px; border:none; background:transparent; color:#94a3b8; font-size:13px; border-radius: var(--r-md); cursor:pointer; transition: all var(--transition-fast); text-align:left; position:relative; }
.net-nav-btn:hover { background:rgba(14,165,233,.08); color:#e2e8f0; }
.net-nav-btn.active { background:rgba(14,165,233,.15); color:#0ea5e9; font-weight:600; }
.net-nav-btn i { width:18px; text-align:center; font-size:14px; }
.net-badge { position:absolute; right:8px; top:50%; transform:translateY(-50%); background:#0ea5e9; color:#fff; font-size:10px; font-weight:700; min-width:18px; height:18px; border-radius: var(--r-md); display:inline-flex; align-items:center; justify-content:center; padding:0 5px; }

/* ─── Main ─── */
.net-main { flex:1; overflow-y:auto; display:flex; flex-direction:column; }
.net-tab { display:none; flex-direction:column; flex:1; padding:20px 24px; gap:16px; overflow-y:auto; }
.net-tab.active { display:flex; }
.net-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:4px; }
.net-header h2 { font-size:18px; font-weight:700; color:#f1f5f9; margin:0; }

/* ─── Buttons ─── */
.net-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 14px; border:none; border-radius: var(--r-md); font-size:12px; font-weight:600; cursor:pointer; transition: all var(--transition-fast); }
.net-btn-sm { padding:6px 10px; font-size:11px; }
.net-btn-primary { background:#0ea5e9; color:#fff; }
.net-btn-primary:hover { background:#0284c7; }
.net-btn-success { background:var(--success); color:#fff; }
.net-btn-success:hover { background:#16a34a; }
.net-btn-danger { background:var(--danger); color:#fff; }
.net-btn-danger:hover { background:#dc2626; }
.net-btn:not(.net-btn-primary):not(.net-btn-success):not(.net-btn-danger) { background:var(--overlay-3); color:#94a3b8; }
.net-btn:not(.net-btn-primary):not(.net-btn-success):not(.net-btn-danger):hover { background:var(--overlay-4); color:#e2e8f0; }
.net-btn:disabled { opacity:.5; pointer-events:none; }

/* ─── Info bar ─── */
.net-info-bar { display:flex; gap:16px; flex-wrap:wrap; padding:12px 16px; background:rgba(14,165,233,.06); border:1px solid rgba(14,165,233,.15); border-radius: var(--r-md); }
.net-info-item { display:flex; align-items:center; gap:8px; font-size:12px; color:#94a3b8; }
.net-info-item i { color:#0ea5e9; font-size:13px; width:16px; text-align:center; }
.net-info-item b { color:#e2e8f0; }

/* ─── Interface cards ─── */
.net-iface-list { display:flex; flex-direction:column; gap:12px; }
.net-iface-card { background:#111827; border:1px solid #1e293b; border-radius: var(--r-lg); overflow:hidden; transition: border-color var(--transition-fast); }
.net-iface-card.up { border-color:rgba(34,197,94,.25); }
.net-iface-card.down { border-color:rgba(239,68,68,.2); }
.net-iface-card:hover { border-color:rgba(14,165,233,.3); }

.net-iface-header { display:flex; align-items:center; gap:14px; padding:14px 18px; }
.net-iface-icon { width:40px; height:40px; border-radius: var(--r-md); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.net-iface-icon.ethernet { background:rgba(59,130,246,.12); color:#3b82f6; }
.net-iface-icon.wifi { background:rgba(14,165,233,.12); color:#0ea5e9; }
.net-iface-title { flex:1; min-width:0; }
.net-iface-title h3 { font-size:15px; font-weight:700; color:#f1f5f9; margin:0; }
.net-iface-type { font-size:11px; color:#64748b; margin-left:8px; }
.net-iface-state { font-size:11px; font-weight:600; margin-left:8px; padding:2px 8px; border-radius: var(--r-sm); }
.net-state-up { background:rgba(34,197,94,.12); color:var(--success); }
.net-state-down { background:rgba(239,68,68,.1); color:var(--danger); }
.net-iface-actions { display:flex; gap:6px; }

.net-iface-body { display:flex; justify-content:space-between; padding:0 18px 14px; gap:20px; flex-wrap:wrap; }
.net-iface-details { display:flex; flex-direction:column; gap:5px; flex:1; }
.net-iface-detail { font-size:12px; color:#94a3b8; display:flex; align-items:center; gap:6px; }
.net-iface-detail i { width:14px; text-align:center; color:#475569; font-size:11px; }
.net-iface-detail b { color:#cbd5e1; }
.net-scope { font-size:10px; color:#475569; }

.net-iface-traffic { display:flex; gap:16px; align-items:flex-end; }
.net-traffic-item { display:flex; align-items:center; gap:6px; font-size:12px; color:#64748b; }
.net-traffic-item .fa-arrow-down { color:var(--success); }
.net-traffic-item .fa-arrow-up { color:#f59e0b; }
.net-traffic-item b { color:#cbd5e1; }

/* ─── WiFi status bar ─── */
.net-wifi-status { margin-bottom:4px; }
.net-wifi-conn-info { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; border-radius: var(--r-md); font-size:13px; }
.net-wifi-conn-info.connected { background:rgba(34,197,94,.08); border:1px solid rgba(34,197,94,.2); color:#a7f3d0; }
.net-wifi-conn-info.disconnected { background:rgba(100,116,139,.08); border:1px solid rgba(100,116,139,.15); color:#94a3b8; }
.net-wifi-conn-info i { margin-right:8px; }
.net-wifi-conn-info b { color:#e2e8f0; }
.net-wifi-signal { margin-left:12px; color:var(--success); }
.net-wifi-ip { margin-left:12px; color:#0ea5e9; }

/* ─── WiFi list ─── */
.net-wifi-list { display:flex; flex-direction:column; gap:3px; }
.net-wifi-item { background:#111827; border:1px solid #1e293b; border-radius: var(--r-md); padding:12px 16px; transition: border-color var(--transition-fast); }
.net-wifi-item:hover { border-color:rgba(14,165,233,.3); }
.net-wifi-item-info { display:flex; align-items:center; gap:12px; }
.net-wifi-item-signal { font-size:18px; width:28px; text-align:center; }
.net-wifi-item-details { flex:1; min-width:0; }
.net-wifi-item-ssid { font-size:14px; font-weight:600; color:#f1f5f9; }
.net-wifi-item-meta { display:flex; align-items:center; gap:6px; font-size:11px; color:#64748b; margin-top:2px; flex-wrap:wrap; }
.net-wifi-item-meta i { font-size:10px; }
.net-wifi-item-sep { color:#334155; }

/* Signal colors */
.net-sig-4 { color:var(--success); }
.net-sig-3 { color:#84cc16; }
.net-sig-2 { color:#f59e0b; }
.net-sig-1 { color:var(--danger); }

/* ─── Saved networks ─── */
.net-saved-list { display:flex; flex-direction:column; gap:6px; }
.net-saved-item { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; background:#111827; border:1px solid #1e293b; border-radius: var(--r-md); }
.net-saved-info { display:flex; align-items:center; gap:10px; }
.net-saved-info i { color:#0ea5e9; font-size:16px; }
.net-saved-name { font-size:14px; font-weight:600; color:#e2e8f0; }
.net-saved-actions { display:flex; gap:6px; }

/* ─── States ─── */
.net-loading { display:flex; align-items:center; justify-content:center; gap:10px; padding:40px; color:#64748b; font-size:13px; }
.net-placeholder { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:60px 20px; color:#475569; text-align:center; }
.net-placeholder i { font-size:36px; opacity:.4; }
.net-placeholder p { font-size:13px; margin:0; }
.net-error { display:flex; align-items:center; gap:10px; padding:16px; background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.2); border-radius: var(--r-md); color:#fca5a5; font-size:13px; }

/* ─── Responsive ─── */
@media (max-width: 900px) {
    .net-sidebar { width:50px; min-width:50px; }
    .net-sidebar-logo span, .net-nav-btn span { display:none; }
    .net-iface-header { flex-wrap:wrap; }
    .net-iface-body { flex-direction:column; }
}

/* ═══════════════════════════════════════════════════════════════════
   Gallery App
   ═══════════════════════════════════════════════════════════════════ */
.gal-app { 
  --gal-accent: #ec4899;
  --gal-accent-light: #f472b6;
  --gal-accent-bg: rgba(236, 72, 153, 0.12);
  display:flex; height:100%; background:var(--bg-surface); color:var(--text-primary); font-family:'Inter',sans-serif; overflow:hidden; 
}

/* ── Sidebar ── */
.gal-sidebar {
  width:220px; min-width:220px; background:var(--bg-surface-alt); border-right:1px solid var(--border);
  display:flex; flex-direction:column; overflow-y:auto; padding:0;
}
.gal-sidebar-section { padding:16px 14px 8px; }
.gal-sidebar-title {
  font-size:10px; text-transform:uppercase; letter-spacing:1.2px; color:var(--text-muted);
  margin-bottom:10px; display:flex; align-items:center; justify-content:space-between;
}
.gal-nav-item {
  display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius: var(--r-md);
  cursor:pointer; color:var(--text-secondary); font-size:13px; transition: all var(--transition-fast); margin-bottom:2px;
}
.gal-nav-item:hover { background:var(--bg-elevated); color:var(--text-primary); }
.gal-nav-item.active { background:linear-gradient(135deg,var(--gal-accent-bg),var(--accent-purple)22); color:var(--gal-accent-light); font-weight:600; }
.gal-nav-item i { width:18px; text-align:center; font-size:14px; }

.gal-type-item {
  display:inline-block; padding:5px 12px; border-radius:20px; font-size:12px;
  cursor:pointer; color:var(--text-muted); border:1px solid transparent; transition: all var(--transition-fast); margin:0 4px 4px 0;
}
.gal-type-item:hover { color:var(--text-secondary); border-color:var(--border-light); }
.gal-type-item.active { background:var(--gal-accent-bg); color:var(--gal-accent-light); border-color:rgba(236, 72, 153, 0.27); font-weight:600; }

/* Sources */
.gal-add-folder-btn {
  background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:13px;
  padding:2px 6px; border-radius: var(--r-sm); transition: all var(--transition-fast);
}
.gal-add-folder-btn:hover { background:var(--bg-secondary); color:var(--gal-accent-light); }
.gal-sources-list { display:flex; flex-direction:column; gap:2px; }
.gal-no-sources { font-size:12px; color:var(--text-muted); padding:8px 0; }
.gal-source-item {
  display:flex; align-items:center; justify-content:space-between; padding:6px 10px;
  border-radius: var(--r-sm); cursor:pointer; transition: all var(--transition-fast);
}
.gal-source-item:hover { background:var(--bg-elevated); }
.gal-source-item.selected { background:var(--gal-accent-bg); }
.gal-source-info { display:flex; align-items:center; gap:8px; overflow:hidden; flex:1; min-width:0; }
.gal-source-label { font-size:12px; color:var(--text-secondary); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.gal-source-count { font-size:10px; color:var(--text-muted); flex-shrink:0; }
.gal-source-del {
  background:none; border:none; color:var(--text-muted); cursor:pointer; padding:2px 4px;
  font-size:11px; border-radius: var(--r-sm); opacity:0; transition: all var(--transition-fast);
}
.gal-source-item:hover .gal-source-del { opacity:1; }
.gal-source-del:hover { color:var(--danger); background:var(--danger)20; }

/* ── Main ── */
.gal-main { flex:1; display:flex; flex-direction:column; overflow:hidden; min-width:0; }
.gal-toolbar {
  display:flex; align-items:center; justify-content:space-between; padding:10px 16px;
  background:var(--bg-surface); border-bottom:1px solid var(--border); flex-shrink:0; gap:12px;
}
.gal-toolbar-left { display:flex; align-items:center; gap:12px; flex:1; min-width:0; }
.gal-toolbar-right { display:flex; align-items:center; gap:8px; flex-shrink:0; }
.gal-search-box {
  display:flex; align-items:center; gap:8px; background:var(--bg-input); border:1px solid var(--border-light);
  border-radius: var(--r-md); padding:6px 12px; flex:1; max-width:320px; transition: border-color var(--transition-fast);
}
.gal-search-box:focus-within { border-color:var(--gal-accent); }
.gal-search-box i { color:var(--text-muted); font-size:13px; }
.gal-search {
  background:none; border:none; color:var(--text-primary); font-size:13px; width:100%; outline:none;
  font-family:inherit;
}
.gal-search::placeholder { color:var(--text-muted); }
.gal-count { font-size:12px; color:var(--text-muted); white-space:nowrap; }
.gal-sort {
  background:var(--bg-input); border:1px solid var(--border-light); border-radius: var(--r-sm); color:var(--text-secondary);
  padding:5px 8px; font-size:12px; cursor:pointer; font-family:inherit;
}
.gal-btn {
  background:var(--bg-input); border:1px solid var(--border-light); color:var(--text-secondary); padding:6px 10px;
  border-radius: var(--r-sm); cursor:pointer; font-size:13px; transition: all var(--transition-fast);
}
.gal-btn:hover { background:var(--gal-accent-bg); border-color:var(--gal-accent); color:var(--gal-accent-light); }
.gal-btn.disabled { opacity:.4; pointer-events:none; }

/* ── Content ── */
.gal-content { flex:1; overflow-y:auto; overflow-x:hidden; padding:12px; position:relative; }

/* ── Grid ── */
.gal-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(180px, 1fr));
  gap:8px;
}
.gal-card {
  border-radius: var(--r-md); overflow:hidden; cursor:pointer; position:relative;
  background:#16161e; transition: transform var(--transition), box-shadow var(--transition);
  aspect-ratio:1/1;
}
.gal-card:hover { transform:scale(1.03); box-shadow:0 8px 30px #00000066; z-index:2; }
.gal-card-img-wrap { width:100%; height:100%; position:relative; }
.gal-card-img-wrap img {
  width:100%; height:100%; object-fit:cover; display:block;
  transition: opacity var(--transition-slow);
}
.gal-card-overlay {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent, #000000cc);
  padding:28px 10px 8px; opacity:0; transition: opacity var(--transition);
}
.gal-card:hover .gal-card-overlay { opacity:1; }
.gal-card-name { font-size:11px; color:var(--text-primary); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; display:block; }
.gal-video-badge {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:44px; height:44px; border-radius:50%; background:#00000088; backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:16px;
  pointer-events:none; transition: transform var(--transition), box-shadow var(--transition);
}
.gal-card:hover .gal-video-badge { transform:translate(-50%,-50%) scale(1.15); }
.gal-fav-badge {
  position:absolute; top:6px; right:6px; color:var(--warning); font-size:14px;
  text-shadow:0 1px 4px rgba(0,0,0,.6); pointer-events:none; z-index:1;
}
.gal-lb-fav-btn.is-fav, .gal-lb-fav-btn[style*="color"] { color:var(--warning) !important; }

/* ── Empty ── */
.gal-empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; color:var(--text-muted); gap:12px;
}
.gal-empty i { font-size:56px; opacity:.3; }
.gal-empty p { font-size:16px; margin:0; }
.gal-empty-hint { font-size:13px; color:var(--border-light); }

/* ── Loader ── */
.gal-loader { display:flex; align-items:center; justify-content:center; padding:20px; }
.gal-spinner {
  width:32px; height:32px; border:3px solid var(--bg-secondary); border-top-color:var(--gal-accent);
  border-radius:50%; animation:gal-spin .7s linear infinite;
}
@keyframes gal-spin { to { transform:rotate(360deg); } }

/* ── Albums ── */
.gal-albums {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));
  gap:12px; padding:4px;
}
.gal-album-card {
  border-radius: var(--r-lg); overflow:hidden; cursor:pointer; background:var(--bg-surface-alt);
  transition: transform var(--transition), box-shadow var(--transition);
}
.gal-album-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px #00000055; }
.gal-album-cover { position:relative; aspect-ratio:4/3; }
.gal-album-cover img { width:100%; height:100%; object-fit:cover; display:block; }
.gal-album-info {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(transparent, #000000dd);
  padding:32px 14px 12px;
}
.gal-album-name { font-size:14px; font-weight:600; color:#fff; }
.gal-album-count { font-size:12px; color:var(--text-secondary); margin-top:2px; }

/* ── Timeline ── */
.gal-timeline-view { padding:8px 0 8px 24px; }
.gal-timeline-group {
  position:relative; padding-left:28px; margin-bottom:24px;
  border-left:2px solid var(--bg-secondary); cursor:pointer; transition: border-color var(--transition-fast);
}
.gal-timeline-group:hover { border-left-color:var(--gal-accent); }
.gal-timeline-header { display:flex; align-items:center; gap:12px; margin-bottom:8px; }
.gal-timeline-dot {
  position:absolute; left:-7px; top:4px; width:12px; height:12px;
  border-radius:50%; background:var(--gal-accent); border:2px solid var(--bg-surface);
}
.gal-timeline-header h3 { margin:0; font-size:15px; font-weight:600; color:var(--text-primary); }
.gal-timeline-count { font-size:12px; color:var(--text-muted); }
.gal-timeline-cover { width:180px; height:120px; border-radius: var(--r-md); overflow:hidden; margin-left:0; }
.gal-timeline-cover img { width:100%; height:100%; object-fit:cover; display:block; }

/* ═══ Lightbox ═══ */
.gal-lightbox {
  position:fixed; top:0; left:0; right:0; bottom:0; z-index:99999;
  display:flex; flex-direction:column;
}
.gal-lb-backdrop { position:absolute; inset:0; background:#000000ee; backdrop-filter:blur(12px); }
.gal-lb-toolbar {
  position:relative; z-index:2; display:flex; align-items:center; justify-content:space-between;
  padding:10px 16px; background:rgba(0,0,0,0.4);
}
.gal-lb-info { display:flex; align-items:center; gap:12px; }
.gal-lb-name { font-size:14px; font-weight:500; color:var(--text-primary); }
.gal-lb-counter { font-size:12px; color:var(--text-muted); }
.gal-lb-actions { display:flex; gap:4px; }
.gal-lb-btn {
  background:none; border:none; color:var(--text-secondary); cursor:pointer; padding:8px 10px;
  border-radius: var(--r-sm); font-size:15px; transition: all var(--transition-fast);
}
.gal-lb-btn:hover { background:rgba(255,255,255,0.08); color:var(--gal-accent-light); }
.gal-lb-content {
  position:relative; z-index:1; flex:1; display:flex; align-items:center;
  justify-content:center; overflow:hidden;
}
.gal-lb-media { display:flex; align-items:center; justify-content:center; max-width:90vw; max-height:80vh; }
.gal-lb-img {
  max-width:90vw; max-height:80vh; object-fit:contain; user-select:none;
  transition: transform var(--transition), box-shadow var(--transition); border-radius: var(--r-sm);
}
.gal-lb-video {
  max-width:90vw; max-height:80vh; border-radius: var(--r-sm); outline:none;
}
.gal-lb-nav {
  position:absolute; top:50%; transform:translateY(-50%); z-index:5;
  background:rgba(0,0,0,0.4); backdrop-filter:blur(6px); border:none; color:var(--text-primary);
  width:48px; height:48px; border-radius:50%; cursor:pointer; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  transition: all var(--transition);
}
.gal-lb-nav:hover { background:rgba(236, 72, 153, 0.4); color:#fff; }
.gal-lb-prev { left:16px; }
.gal-lb-next { right:16px; }

/* EXIF panel */
.gal-lb-exif {
  position:absolute; right:0; top:0; bottom:0; width:320px; z-index:10;
  background:rgba(16, 24, 39, 0.93); backdrop-filter:blur(16px); border-left:1px solid var(--bg-secondary);
  display:flex; flex-direction:column; overflow-y:auto; padding:20px;
}
.gal-lb-exif h4 { margin:0 0 16px; font-size:14px; color:var(--gal-accent-light); display:flex; align-items:center; gap:8px; }
.gal-exif-table { width:100%; font-size:12px; border-collapse:collapse; }
.gal-exif-table td { padding:7px 8px; border-bottom:1px solid var(--bg-secondary); color:var(--text-secondary); vertical-align:top; }
.gal-exif-table td:first-child { color:var(--text-muted); white-space:nowrap; width:90px; }
.gal-map-link {
  display:inline-flex; align-items:center; gap:6px; margin-top:14px; padding:8px 14px;
  background:var(--bg-secondary); border-radius: var(--r-md); color:var(--info); font-size:12px; text-decoration:none;
  transition: background var(--transition-fast);
}
.gal-map-link:hover { background:var(--border-light); }

/* ── People view ── */
.gal-people-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(130px, 1fr)); gap:16px; padding:8px 0;
}
.gal-person-card {
  text-align:center; padding:16px 8px; border-radius:12px; cursor:pointer;
  transition:background .15s, transform .15s; position:relative;
}
.gal-person-card:hover { background:var(--bg-hover); transform:translateY(-2px); }
.gal-person-del {
  position:absolute; top:6px; right:6px; width:24px; height:24px; border-radius:50%;
  background:rgba(0,0,0,0.4); border:none; color:#fff; font-size:11px; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity .15s;
}
.gal-person-card:hover .gal-person-del { opacity:1; }
.gal-person-del:hover { background:#ef4444; }
.gal-person-avatar {
  width:80px; height:80px; margin:0 auto 8px; border-radius:50%; overflow:hidden;
  background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center;
  font-size:32px; color:var(--text-secondary);
}
.gal-person-avatar img { width:100%; height:100%; object-fit:cover; }
.gal-person-name { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gal-person-count { font-size:11px; color:var(--text-secondary); margin-top:2px; }

/* Person detail */
.gal-person-detail { padding:0; }
.gal-person-header {
  display:flex; align-items:center; gap:16px; padding:12px 0; margin-bottom:8px;
  border-bottom:1px solid var(--border-color); flex-wrap:wrap;
}
.gal-person-back { flex-shrink:0; }
.gal-person-title { display:flex; align-items:center; gap:12px; flex:1; min-width:200px; }
.gal-person-big-avatar {
  width:56px; height:56px; border-radius:50%; overflow:hidden; flex-shrink:0;
  background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center;
  font-size:24px; color:var(--text-secondary);
}
.gal-person-big-avatar img { width:100%; height:100%; object-fit:cover; }
.gal-person-edit-name {
  font-size:20px; font-weight:700; margin:0; outline:none; border-bottom:2px solid transparent;
  padding:2px 4px; border-radius:4px; transition:border-color .15s;
}
.gal-person-edit-name:hover { border-bottom-color:var(--border-light); }
.gal-person-edit-name:focus { border-bottom-color:var(--accent-color); background:var(--bg-secondary); }
.gal-person-actions { display:flex; gap:6px; flex-shrink:0; }

/* Face thumbnails grid (for false-positive management) */
.gal-person-faces-grid {
  display:flex; flex-wrap:wrap; gap:6px;
}
.gal-pf-thumb {
  width:64px; height:64px; border-radius:8px; overflow:hidden; cursor:pointer;
  position:relative; border:2px solid transparent; transition:all .15s;
}
.gal-pf-thumb img { width:100%; height:100%; object-fit:cover; }
.gal-pf-thumb:hover { border-color:var(--border-light); }
.gal-pf-thumb.selected { border-color:#ef4444; box-shadow:0 0 8px rgba(239,68,68,0.4); }
.gal-pf-check {
  position:absolute; top:2px; right:2px; width:20px; height:20px; border-radius:50%;
  background:rgba(0,0,0,0.5); display:flex; align-items:center; justify-content:center;
  font-size:10px; color:#fff; transition:background .15s, opacity .15s;
  opacity:0; pointer-events:none;
}
.gal-pf-thumb:hover .gal-pf-check { opacity:0.6; }
.gal-pf-check.checked { background:#ef4444; opacity:1; }
.gal-pf-thumb.selected .gal-pf-check { opacity:1; }

/* Person photos grid */
.gal-person-photos-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:6px;
}
.gal-person-photos-grid .gal-card { border-radius:8px; }

/* AI sidebar section */
.gal-ai-section { border-top:1px solid var(--border-color); padding-top:10px; }
.gal-ai-progress { margin-top:8px; }
.gal-ai-progress-bar { height:4px; background:var(--bg-tertiary); border-radius:2px; overflow:hidden; }
.gal-ai-progress-fill { height:100%; width:0; background:var(--accent-color); border-radius:2px; transition:width .3s; }
.gal-ai-progress-text { font-size:11px; color:var(--text-secondary); margin-top:4px; }

/* Tags, Search, Merge views */
.gal-tag-chips { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:16px; }
.gal-tag-chip {
  padding:6px 12px; background:var(--bg-secondary); border:1px solid var(--border-color);
  border-radius:16px; font-size:13px; cursor:pointer; transition:all .15s;
}
.gal-tag-chip:hover { border-color:var(--accent-color); }
.gal-tag-chip.active { background:var(--accent-color); color:#fff; border-color:var(--accent-color); }
.gal-tag-chip small { opacity:.6; margin-left:2px; }
.gal-ai-search-box {
  display:flex; align-items:center; gap:8px; padding:8px 14px;
  background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:8px;
  margin-bottom:16px; max-width:500px;
}
.gal-ai-search-input {
  flex:1; background:none; border:none; color:var(--text-primary); font-size:14px; outline:none;
}
.gal-merge-list { display:flex; flex-direction:column; gap:12px; max-width:600px; }
.gal-merge-card {
  background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:12px;
  padding:16px; transition:opacity .3s;
}
.gal-merge-pair { display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:12px; }
.gal-merge-person { text-align:center; min-width:90px; }
.gal-merge-avatar {
  width:64px; height:64px; margin:0 auto 6px; border-radius:50%; overflow:hidden;
  background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center;
  font-size:24px; color:var(--text-secondary);
}
.gal-merge-avatar img { width:100%; height:100%; object-fit:cover; }
.gal-merge-name { font-size:13px; font-weight:600; }
.gal-merge-arrow { text-align:center; color:var(--text-secondary); font-size:18px; }
.gal-merge-conf { font-size:11px; color:var(--accent-color); margin-top:2px; font-weight:600; }
.gal-merge-actions { display:flex; gap:8px; justify-content:center; }

/* ── Face detection overlay ── */
.gal-lb-faces-panel {
  position:absolute; right:0; top:0; bottom:0; width:320px; z-index:10;
  background:rgba(16, 24, 39, 0.93); backdrop-filter:blur(16px); border-left:1px solid var(--bg-secondary);
  display:flex; flex-direction:column; overflow-y:auto; padding:20px;
}
.gal-lb-faces-panel h4 { margin:0 0 14px; font-size:14px; color:var(--gal-accent-light); display:flex; align-items:center; gap:8px; }
.gal-faces-list { display:flex; flex-direction:column; gap:2px; }
.gal-face-item {
  display:flex; align-items:center; gap:10px; padding:8px 6px; border-radius:8px;
  cursor:pointer; transition:background .15s;
}
.gal-face-item:hover { background:rgba(255,255,255,0.05); }
.gal-face-thumb { width:44px; height:44px; border-radius:50%; object-fit:cover; flex-shrink:0; border:2px solid var(--bg-secondary); }
.gal-face-info { flex:1; min-width:0; }
.gal-face-name { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gal-face-identify-btn {
  margin-top:3px; padding:3px 8px; border:1px solid rgba(236,72,153,0.3); background:rgba(236,72,153,0.1);
  color:var(--gal-accent-light); border-radius:4px; font-size:11px; cursor:pointer; display:inline-flex; align-items:center; gap:4px;
  transition:all .15s;
}
.gal-face-identify-btn:hover { background:rgba(236,72,153,0.3); }
.gal-faces-empty { color:var(--text-secondary); font-size:13px; margin:8px 0; }
.gal-faces-hint { color:var(--text-muted); font-size:12px; margin-top:4px; }
.gal-faces-tags { display:flex; flex-wrap:wrap; gap:6px; margin-top:6px; }
.gal-face-tag {
  padding:4px 8px; background:var(--bg-secondary); border:1px solid var(--border-color);
  border-radius:12px; font-size:11px; color:var(--text-secondary);
}
.gal-face-tag small { opacity:.6; }

/* Face bounding boxes */
.gal-face-box {
  border:2px solid rgba(236,72,153,0.6); border-radius:4px; transition:all .2s;
}
.gal-face-box:hover, .gal-face-box-active {
  border-color:#ec4899; box-shadow:0 0 12px rgba(236,72,153,0.5); background:rgba(236,72,153,0.08);
}
.gal-face-label {
  position:absolute; bottom:-20px; left:50%; transform:translateX(-50%); white-space:nowrap;
  font-size:11px; font-weight:600; color:#fff; background:rgba(0,0,0,0.7); padding:2px 6px;
  border-radius:3px; pointer-events:none;
}

/* Face identification modal */
.gal-face-modal { position:fixed; inset:0; z-index:200000; display:flex; align-items:center; justify-content:center; }
.gal-face-modal-backdrop { position:absolute; inset:0; background:#000000aa; backdrop-filter:blur(6px); }
.gal-face-modal-content {
  position:relative; z-index:1; background:var(--bg-surface-alt); border:1px solid var(--border-light);
  border-radius:14px; padding:24px; width:420px; max-height:80vh; overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.gal-face-modal-content h3 { margin:0 0 14px; display:flex; align-items:center; gap:8px; font-size:16px; }
.gal-face-modal-thumb { text-align:center; margin-bottom:14px; }
.gal-face-modal-thumb img { width:80px; height:80px; border-radius:50%; object-fit:cover; border:3px solid var(--gal-accent); }
.gal-face-modal-hint { font-size:13px; color:var(--text-secondary); margin:0 0 10px; }
.gal-face-matches { display:flex; flex-direction:column; gap:4px; margin-bottom:14px; }
.gal-face-match {
  display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:8px;
  cursor:pointer; border:1px solid var(--border-color); transition:all .15s;
}
.gal-face-match:hover { background:rgba(236,72,153,0.1); border-color:var(--gal-accent); }
.gal-face-match-current { border-color:var(--gal-accent); background:rgba(236,72,153,0.08); }
.gal-face-match img { width:40px; height:40px; border-radius:50%; object-fit:cover; flex-shrink:0; }
.gal-face-match-name { font-size:13px; font-weight:600; }
.gal-face-match-conf { font-size:11px; color:var(--text-secondary); }
.gal-face-new-name { display:flex; gap:8px; margin:12px 0; }
.gal-face-name-input {
  flex:1; padding:8px 12px; border:1px solid var(--border-color); background:var(--bg-secondary);
  border-radius:6px; color:var(--text-primary); font-size:13px; outline:none;
}
.gal-face-name-input:focus { border-color:var(--gal-accent); }
.gal-face-modal-close { margin-top:6px; width:100%; }

/* ── Folder picker modal ── */
.gal-folder-modal-overlay {
  position:fixed; inset:0; z-index:100000; background:#00000088; backdrop-filter:blur(4px);
  display:flex; align-items:center; justify-content:center;
}
.gal-folder-modal {
  background:var(--bg-surface-alt); border:1px solid var(--border-light); border-radius:14px; width:520px;
  max-height:70vh; display:flex; flex-direction:column; overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
}
.gal-folder-modal-header {
  display:flex; align-items:center; justify-content:space-between; padding:16px 20px;
  border-bottom:1px solid var(--bg-secondary);
}
.gal-folder-modal-header h3 { margin:0; font-size:16px; color:var(--text-primary); display:flex; align-items:center; gap:10px; }
.gal-folder-modal-header h3 i { color:var(--gal-accent); }
.gal-folder-modal-close { background:none; border:none; color:var(--text-muted); cursor:pointer; font-size:16px; padding:4px 8px; border-radius: var(--r-sm); }
.gal-folder-modal-close:hover { color:var(--text-primary); background:var(--bg-secondary); }
.gal-folder-modal-path {
  padding:10px 20px; font-size:13px; color:var(--text-secondary); background:var(--bg-surface);
  display:flex; align-items:center; gap:8px;
}
.gal-folder-media-count {
  margin-left:auto; font-size:11px; color:var(--success); background:var(--success)20;
  padding:2px 8px; border-radius: var(--r-md);
}
.gal-folder-modal-list { flex:1; overflow-y:auto; padding:8px; }
.gal-folder-modal-item {
  display:flex; align-items:center; gap:10px; padding:10px 14px; border-radius: var(--r-md);
  cursor:pointer; font-size:13px; color:var(--text-secondary); transition: all var(--transition-fast);
}
.gal-folder-modal-item:hover { background:var(--bg-secondary); }
.gal-folder-parent { color:var(--text-muted); }
.gal-folder-modal-empty { padding:24px; text-align:center; color:var(--text-muted); font-size:13px; }
.gal-folder-modal-footer { padding:12px 20px; border-top:1px solid var(--bg-secondary); text-align:right; }
.gal-folder-modal-warning {
    margin-top: 8px;
    font-size: 0.85em;
    text-align: left;
    color: var(--danger);
}
.gal-folder-add-btn {
  background:linear-gradient(135deg,#ec4899,var(--accent-purple)); border:none; color:#fff;
  padding:8px 20px; border-radius: var(--r-md); cursor:pointer; font-size:13px; font-weight:600;
  transition: all var(--transition-fast);
}
.gal-folder-add-btn:hover { opacity:.9; transform:translateY(-1px); }
.gal-folder-add-btn.disabled { background:#1e293b; color:#475569; cursor:default; transform:none; }

/* ── Multi-select ── */
.gal-card-select {
  position:absolute; top:6px; left:6px; z-index:3;
}
.gal-card-check {
  width:18px; height:18px; cursor:pointer; accent-color:#ec4899;
}
.gal-card.selected { outline:3px solid #ec4899; outline-offset:-3px; }
.gal-batch-bar {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:9999;
  background:#1e293b; border:1px solid #334155; border-radius: var(--r-lg);
  padding:10px 20px; display:flex; align-items:center; gap:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.5); backdrop-filter:blur(8px);
}
.gal-batch-count { color:#94a3b8; font-size:13px; margin-right:8px; }
.gal-batch-bar button {
  background:none; border:none; color:#cbd5e1; cursor:pointer;
  padding:8px 12px; border-radius: var(--r-md); font-size:14px; transition: all var(--transition-fast);
}
.gal-batch-bar button:hover { background:#334155; color:#f8fafc; }
.gal-batch-cancel { color:var(--danger) !important; font-size:13px !important; }
.gal-select-toggle { font-size:13px !important; }

/* ── Drop zone ── */
.gal-drop-overlay {
  position:absolute; inset:0; z-index:100; display:flex;
  align-items:center; justify-content:center;
  background:rgba(15,23,42,.85); backdrop-filter:blur(4px);
}
.gal-drop-zone {
  padding:60px; border:3px dashed #ec4899; border-radius:24px;
  text-align:center; color:#e2e8f0;
}
.gal-drop-zone i { font-size:48px; color:#ec4899; display:block; margin-bottom:16px; }
.gal-drop-zone p { font-size:18px; margin:0; }

/* ── Upload modal ── */
.gal-upload-overlay {
  position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.7);
  backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center;
}
.gal-upload-modal {
  background:#1a1a2e; border:1px solid rgba(255,255,255,.08); border-radius:16px;
  width:520px; max-width:95vw; max-height:85vh; display:flex; flex-direction:column;
  overflow:hidden; box-shadow:0 24px 80px rgba(0,0,0,.6);
}
.gal-upload-modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 20px; border-bottom:1px solid rgba(255,255,255,.06);
}
.gal-upload-modal-title { font-size:15px; font-weight:700; color:#fff; display:flex; align-items:center; gap:8px; }
.gal-upload-modal-title i { color:#ec4899; }
.gal-upload-modal-close { background:none; border:none; color:rgba(255,255,255,.5); cursor:pointer; font-size:16px; padding:4px 8px; border-radius:6px; }
.gal-upload-modal-close:hover { color:#fff; background:rgba(255,255,255,.08); }
.gal-upload-modal-close:disabled { opacity:.3; cursor:not-allowed; }
.gal-upload-dest {
  padding:14px 20px; border-bottom:1px solid rgba(255,255,255,.06);
  display:flex; flex-direction:column; gap:8px;
}
.gal-upload-dest-label { font-size:11px; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.05em; }
.gal-upload-folder-sel {
  width:100%; padding:8px 10px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1);
  border-radius:8px; color:#fff; font-size:13px; cursor:pointer;
}
.gal-upload-folder-sel:focus { outline:none; border-color:#ec4899; }
.gal-upload-date-label {
  display:flex; align-items:center; gap:8px; font-size:12px; color:rgba(255,255,255,.6); cursor:pointer;
}
.gal-upload-date-label input { accent-color:#ec4899; cursor:pointer; }
.gal-uq-list { flex:1; overflow-y:auto; padding:8px 12px; display:flex; flex-direction:column; gap:4px; }
.gal-uq-item {
  display:flex; align-items:center; gap:10px; padding:8px 10px;
  border-radius:8px; background:rgba(255,255,255,.04);
}
.gal-uq-icon { width:28px; text-align:center; color:#ec4899; font-size:14px; flex-shrink:0; }
.gal-uq-info { flex:1; min-width:0; }
.gal-uq-name { font-size:12px; color:#fff; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-bottom:2px; }
.gal-uq-size { font-size:10px; color:rgba(255,255,255,.35); margin-bottom:4px; }
.gal-uq-bar-wrap { height:3px; background:rgba(255,255,255,.1); border-radius:2px; overflow:hidden; }
.gal-uq-bar { height:100%; background:#ec4899; border-radius:2px; transition:width .15s; }
.gal-uq-status { flex-shrink:0; font-size:14px; }
.gal-uq-pct { font-size:11px; color:#ec4899; font-weight:700; }
.gal-upload-modal-footer {
  padding:12px 20px; border-top:1px solid rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:space-between;
}
.gal-upload-summary { font-size:12px; color:rgba(255,255,255,.4); }
/* Sync indicator in toolbar */
.gal-sync-indicator {
  display:flex; align-items:center; gap:6px; font-size:12px;
  color:#ec4899; padding:4px 10px; border-radius:20px;
  background:rgba(236,72,153,.1); border:1px solid rgba(236,72,153,.2);
}
/* PWA sync banner */
.gal-sync-banner {
  display:flex; align-items:center; gap:10px; padding:10px 16px;
  background:linear-gradient(135deg,rgba(236,72,153,.15),rgba(99,102,241,.1));
  border-bottom:1px solid rgba(236,72,153,.2); font-size:13px; color:#fff;
  flex-shrink:0;
}
.gal-sync-banner i { color:#ec4899; font-size:14px; }
.gal-sync-banner span { flex:1; }
.gal-sync-banner strong { color:#ec4899; }
.gal-sync-banner-close { background:none; border:none; color:rgba(255,255,255,.4); cursor:pointer; padding:2px 6px; border-radius:4px; font-size:13px; }
.gal-sync-banner-close:hover { color:#fff; background:rgba(255,255,255,.08); }


/* ── Map view ── */
.gal-map-view { width:100%; height:100%; position:relative; }

/* ── Stats modal ── */
.gal-stat-grid {
  display:grid; grid-template-columns:repeat(2, 1fr); gap:12px;
}
.gal-stat-card {
  background:#1e293b; border-radius: var(--r-lg); padding:16px; text-align:center;
}
.gal-stat-num { font-size:24px; font-weight:700; color:#ec4899; }
.gal-stat-label { font-size:12px; color:#64748b; margin-top:4px; }
.gal-formats-list { display:flex; flex-wrap:wrap; gap:6px; }
.gal-format-tag {
  background:#1e293b; padding:4px 10px; border-radius: var(--r-sm);
  font-size:12px; color:#94a3b8;
}
.gal-format-tag b { color:#ec4899; margin-left:4px; }

/* ── Custom albums sidebar ── */
.gal-custom-albums-list { display:flex; flex-direction:column; gap:2px; }
.gal-custom-album-item {
  display:flex; align-items:center; justify-content:space-between;
  padding:6px 12px; border-radius: var(--r-sm); cursor:pointer; font-size:13px;
  color:#cbd5e1; transition: all var(--transition-fast);
}
.gal-custom-album-item:hover { background:#1e293b; }
.gal-custom-album-item .gal-album-item-count {
  font-size:11px; color:#64748b; background:#0f172a; padding:2px 6px; border-radius: var(--r-sm);
}

/* ── Responsive: Tablet ≤768px ── */
@media (max-width: 768px) {
  .gal-sidebar { width:56px; min-width:56px; }
  .gal-sidebar-title, .gal-source-label, .gal-source-count,
  .gal-type-item, .gal-nav-item span { display:none; }
  .gal-nav-item { justify-content:center; padding:12px; }
  .gal-grid { grid-template-columns:repeat(auto-fill, minmax(120px, 1fr)); gap:4px; }
  .gal-albums { grid-template-columns:repeat(auto-fill, minmax(180px, 1fr)); gap:8px; }
  .gal-toolbar { padding:8px 10px; gap:8px; }
  .gal-toolbar-right { gap:4px; }
  .gal-search-box { max-width:200px; padding:5px 10px; }
  .gal-content { padding:8px; }
  .gal-lb-exif { width:100%; max-width:100%; height:40vh; border-left:none; border-top:1px solid var(--bg-secondary); position:relative; top:auto; bottom:auto; right:auto; }
  .gal-lb-toolbar { padding:8px 10px; flex-wrap:wrap; gap:4px; }
  .gal-lb-info { gap:8px; min-width:0; flex:1; }
  .gal-lb-name { font-size:13px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .gal-lb-actions { flex-wrap:wrap; gap:2px; }
  .gal-lb-btn { padding:8px; font-size:16px; min-width:40px; min-height:40px; display:flex; align-items:center; justify-content:center; }
  .gal-lb-nav { width:40px; height:40px; font-size:16px; }
  .gal-lb-prev { left:8px; }
  .gal-lb-next { right:8px; }
  .gal-lb-media { max-width:100vw; max-height:70vh; }
  .gal-lb-img { max-width:100vw; max-height:70vh; }
  .gal-lb-video { max-width:100vw; max-height:70vh; }
  .gal-batch-bar { bottom:8px; left:8px; right:8px; transform:none; padding:8px 12px; gap:8px; }
  .gal-folder-modal { width:calc(100vw - 32px); max-width:520px; }
  .gal-drop-zone { padding:32px; }
  .gal-drop-zone i { font-size:36px; }
  .gal-drop-zone p { font-size:15px; }
  .gal-stat-grid { grid-template-columns:repeat(2, 1fr); gap:8px; }
  .gal-timeline-cover { width:140px; height:95px; }
}

/* ── Responsive: Phone ≤480px ── */
@media (max-width: 480px) {
  .gal-sidebar { width:44px; min-width:44px; }
  .gal-nav-item { padding:10px 0; justify-content:center; }
  .gal-nav-item i { width:auto; font-size:15px; }
  .gal-sidebar-section { padding:10px 4px 6px; }
  .gal-grid { grid-template-columns:repeat(auto-fill, minmax(100px, 1fr)); gap:3px; }
  .gal-card { border-radius:var(--r-sm); }
  .gal-card-overlay { display:none; }
  .gal-video-badge { width:32px; height:32px; font-size:12px; }
  .gal-albums { grid-template-columns:repeat(auto-fill, minmax(140px, 1fr)); gap:6px; }
  .gal-album-info { padding:20px 10px 8px; }
  .gal-album-name { font-size:12px; }
  .gal-album-count { font-size:10px; }
  .gal-toolbar { padding:6px 8px; gap:6px; flex-wrap:wrap; }
  .gal-toolbar-left { flex:1 1 100%; order:2; }
  .gal-toolbar-right { flex:1 1 100%; order:1; justify-content:flex-end; }
  .gal-search-box { max-width:none; flex:1; }
  .gal-count { display:none; }
  .gal-sort { font-size:11px; padding:4px 6px; }
  .gal-btn { padding:6px 8px; font-size:12px; }
  .gal-content { padding:4px; }
  .gal-lb-toolbar { padding:6px 8px; }
  .gal-lb-actions { gap:0; }
  .gal-lb-btn { padding:6px; font-size:15px; min-width:36px; min-height:36px; }
  .gal-lb-info-btn, .gal-lb-zoom-in, .gal-lb-zoom-out, .gal-lb-rotate { display:none; }
  .gal-lb-nav { width:36px; height:36px; font-size:14px; opacity:0.6; }
  .gal-lb-prev { left:4px; }
  .gal-lb-next { right:4px; }
  .gal-lb-media { max-width:100vw; max-height:75vh; }
  .gal-lb-img { max-width:100vw; max-height:75vh; border-radius:0; }
  .gal-lb-video { max-width:100vw; max-height:75vh; border-radius:0; }
  .gal-lb-exif { height:50vh; padding:14px; }
  .gal-lb-exif h4 { font-size:13px; margin-bottom:10px; }
  .gal-exif-table td { padding:5px 6px; font-size:11px; }
  .gal-exif-table td:first-child { width:75px; }
  .gal-batch-bar { bottom:4px; left:4px; right:4px; padding:6px 10px; gap:6px; border-radius:var(--r-md); }
  .gal-batch-bar button { padding:6px 8px; font-size:13px; }
  .gal-batch-count { font-size:12px; }
  .gal-folder-modal { width:calc(100vw - 16px); max-height:80vh; border-radius:var(--r-lg); }
  .gal-folder-modal-header { padding:12px 14px; }
  .gal-folder-modal-header h3 { font-size:14px; }
  .gal-folder-modal-path { padding:8px 14px; font-size:12px; }
  .gal-folder-modal-item { padding:8px 10px; font-size:12px; }
  .gal-stat-grid { grid-template-columns:1fr; }
  .gal-empty i { font-size:40px; }
  .gal-empty p { font-size:14px; }
  .gal-empty-hint { font-size:12px; }
  .gal-timeline-view { padding:6px 0 6px 12px; }
  .gal-timeline-group { padding-left:16px; margin-bottom:16px; }
  .gal-timeline-cover { width:110px; height:75px; }
  .gal-timeline-header h3 { font-size:13px; }
  .gal-drop-zone { padding:24px; border-width:2px; border-radius:16px; }
  .gal-drop-zone i { font-size:28px; margin-bottom:10px; }
  .gal-drop-zone p { font-size:14px; }
}

/* ── Responsive: Phone landscape ── */
@media (max-height: 480px) and (orientation: landscape) {
  .gal-sidebar { width:0; min-width:0; overflow:hidden; border:none; }
  .gal-grid { grid-template-columns:repeat(auto-fill, minmax(100px, 1fr)); gap:3px; }
  .gal-toolbar { padding:4px 8px; }
  .gal-content { padding:4px; }
  .gal-lb-toolbar { padding:4px 8px; }
  .gal-lb-btn { padding:4px 6px; font-size:14px; min-width:32px; min-height:32px; }
  .gal-lb-media { max-height:calc(100vh - 50px); }
  .gal-lb-img { max-height:calc(100vh - 50px); }
  .gal-lb-video { max-height:calc(100vh - 50px); }
  .gal-lb-nav { width:32px; height:32px; font-size:13px; }
}

/* ═══════════════════════════════════════════════════════════
   Backup App — Wizard-style sidebar layout
   ═══════════════════════════════════════════════════════════ */
.bak-app { flex-direction: row !important; }

/* ── Sidebar ── */
.bak-sidebar { width: 200px; min-width: 200px; background: rgba(0,0,0,0.25); border-right: 1px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; }
.bak-sidebar-header { padding: 16px; border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 10px; }
.bak-sidebar-icon { width: 36px; height: 36px; border-radius: var(--r-md); background: rgba(79,140,255,0.15); display: flex; align-items: center; justify-content: center; color: var(--accent); font-size: 1.1em; flex-shrink: 0; }
.bak-sidebar-title { font-weight: 700; font-size: 0.95em; color: var(--text); }
.bak-sidebar-sub { font-size: 0.72em; color: var(--text-muted); margin-top: 2px; }
.bak-nav { flex: 1; overflow-y: auto; padding: 8px 0; }
.bak-nav-item { display: flex; align-items: center; gap: 10px; padding: 10px 16px; color: var(--text-muted); cursor: pointer; transition: all var(--transition-fast); font-size: 0.88em; border-left: 3px solid transparent; text-decoration: none; user-select: none; }
.bak-nav-item:hover { background: var(--overlay-2); color: var(--text); }
.bak-nav-item.active { background: rgba(79,140,255,0.1); color: var(--accent); border-left-color: var(--accent); font-weight: 600; }
.bak-nav-item i { width: 18px; text-align: center; font-size: 0.95em; }
.bak-nav-sep { height: 1px; background: var(--border); margin: 6px 16px; }
.bak-content { flex: 1; display: flex; flex-direction: column; overflow: hidden; position: relative; }

/* ── Dashboard panel ── */
.bak-dash-welcome { margin-bottom: 20px; }
.bak-dash-welcome h2 { font-size: 1.25em; margin: 0 0 6px; display: flex; align-items: center; gap: 10px; }
.bak-dash-welcome p { color: var(--text-muted); font-size: 0.9em; margin: 0; }
.bak-dash-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-bottom: 20px; }
.bak-dash-card { display: flex; align-items: center; gap: 14px; padding: 18px 16px; background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-lg); cursor: pointer; transition: all var(--transition); user-select: none; }
.bak-dash-card:hover { border-color: rgba(79,140,255,0.4); transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.bak-dash-card-icon { width: 48px; height: 48px; border-radius: var(--r-lg); display: flex; align-items: center; justify-content: center; font-size: 1.3em; flex-shrink: 0; }
.bak-dash-card-text { flex: 1; min-width: 0; }
.bak-dash-card-text strong { display: block; font-size: 0.95em; margin-bottom: 3px; color: var(--text); }
.bak-dash-card-text span { font-size: 0.8em; color: var(--text-muted); line-height: 1.3; }
.bak-dash-arrow { color: var(--text-muted); opacity: 0.4; font-size: 0.85em; transition: opacity var(--transition); }
.bak-dash-card:hover .bak-dash-arrow { opacity: 0.8; }
.bak-dash-green .bak-dash-card-icon { background: rgba(16,185,129,0.15); color: #34d399; }
.bak-dash-blue .bak-dash-card-icon { background: rgba(59,130,246,0.15); color: #60a5fa; }
.bak-dash-orange .bak-dash-card-icon { background: rgba(251,146,60,0.15); color: #fb923c; }
.bak-dash-purple .bak-dash-card-icon { background: rgba(168,85,247,0.15); color: #c084fc; }
.bak-dash-green:hover { border-color: rgba(16,185,129,0.4); }
.bak-dash-blue:hover { border-color: rgba(59,130,246,0.4); }
.bak-dash-orange:hover { border-color: rgba(251,146,60,0.4); }
.bak-dash-purple:hover { border-color: rgba(168,85,247,0.4); }

/* ── Shield status widget ── */
.bak-shield-status { display: flex; align-items: center; gap: 14px; padding: 14px 18px; margin-bottom: 18px; border-radius: var(--r-lg); border: 1px solid var(--border); background: var(--overlay-1); }
.bak-shield-icon { font-size: 2em; flex-shrink: 0; width: 48px; text-align: center; }
.bak-shield-info { flex: 1; min-width: 0; }
.bak-shield-label { font-weight: 600; font-size: 0.95em; }
.bak-shield-detail { font-size: 0.82em; color: var(--text-muted); margin-top: 2px; }
.bak-shield-status.bak-shield-ok { border-color: rgba(16,185,129,0.4); }
.bak-shield-status.bak-shield-ok .bak-shield-icon { color: #34d399; }
.bak-shield-status.bak-shield-warning { border-color: rgba(251,191,36,0.4); }
.bak-shield-status.bak-shield-warning .bak-shield-icon { color: #fbbf24; }
.bak-shield-status.bak-shield-error { border-color: rgba(239,68,68,0.4); }
.bak-shield-status.bak-shield-error .bak-shield-icon { color: var(--danger); }
.bak-shield-status.bak-shield-unknown { border-color: var(--border); }
.bak-shield-status.bak-shield-unknown .bak-shield-icon { color: var(--text-muted); }

/* ── Snapshot space widget ── */
.bak-snap-space { padding: 12px 16px; margin-bottom: 14px; background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); }

/* ── Snapshot browse modal tree ── */
.snap-browse-dir { margin-bottom: 2px; }
.snap-browse-dir summary { cursor: pointer; padding: 3px 6px; border-radius: var(--r-sm); font-weight: 600; font-size: 13px; }
.snap-browse-dir summary:hover { background: var(--overlay-2); }
.snap-browse-dir summary i { margin-right: 6px; color: #fbbf24; }
.snap-browse-files { padding-left: 22px; }
.snap-browse-file { display: flex; justify-content: space-between; padding: 2px 6px; font-size: 12px; color: var(--text-muted); border-radius: var(--r-sm); }
.snap-browse-file:hover { background: var(--overlay-2); }
.snap-browse-file i { margin-right: 6px; color: var(--text-muted); opacity: 0.6; }

/* ── Dashboard summary cards ── */
.bak-dash-summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.bak-dash-stat { padding: 14px; background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); text-align: center; }
.bak-dash-stat-val { font-size: 1.6em; font-weight: 700; color: var(--accent); display: block; }
.bak-dash-stat-label { font-size: 0.78em; color: var(--text-muted); margin-top: 2px; display: block; }
.bak-dash-stat-icon { font-size: 1.1em; color: var(--text-muted); opacity: 0.5; margin-bottom: 4px; display: block; }

/* ── Panel subtitles ── */
.bak-panel-desc { color: var(--text-muted); font-size: 0.85em; margin: -6px 0 16px; line-height: 1.4; }
.bak-panel-desc i { margin-right: 4px; }

/* ── Backup wizard steps ── */
.bak-step { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 20px; }
.bak-step-num { width: 28px; height: 28px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 0.82em; font-weight: 700; flex-shrink: 0; margin-top: 2px; }
.bak-step-body { flex: 1; }
.bak-step-label { font-weight: 600; font-size: 0.9em; margin-bottom: 6px; }

/* ═══ Sharing App ═══ */
.shr-loading { display: flex; align-items: center; justify-content: center; height: 100%; color: var(--text-muted); }
.shr-spin-icon { margin-right: var(--space-sm); }
.shr-empty { display: flex; flex-direction: column; align-items: center; justify-content: center; height: 100%; gap: var(--space-lg); padding: 40px; text-align: center; }
.shr-empty-icon { font-size: 48px; color: var(--text-muted); opacity: .4; }
.shr-empty-title { margin: 0; font-size: var(--fs-md); color: var(--text); }
.shr-empty-text { margin: 0; font-size: 13px; color: var(--text-muted); max-width: 340px; }
.shr-link { color: var(--accent); text-decoration: underline; }
.shr-sidebar { width: 150px; min-width: 150px; flex-shrink: 0; border-right: 1px solid var(--border); display: flex; flex-direction: column; padding: var(--space-sm) 0; overflow-y: auto; background: var(--bg-secondary, rgba(0, 0, 0, .02)); }
.shr-tab-btn { display: flex; align-items: center; gap: var(--space-sm); padding: 10px 14px; border: none; background: none; cursor: pointer; text-align: left; font-size: 13px; color: var(--text-muted); transition: all .15s; border-left: 3px solid transparent; width: 100%; }
.shr-tab-icon { font-size: var(--fs-sm); width: 16px; text-align: center; }
.shr-panel { flex: 1; overflow-y: auto; padding: var(--space-lg) var(--space-xl); }
.shr-header { display: flex; align-items: center; gap: 10px; margin-bottom: var(--space-md); flex-wrap: wrap; }
.shr-title { font-weight: 600; font-size: 15px; }
.shr-icon-accent { margin-right: 6px; color: var(--accent); }
.shr-spacer { flex: 1; }
.shr-desc { font-size: var(--fs-sm); color: var(--text-muted); margin-bottom: 10px; }
.shr-empty-msg { text-align: center; padding: var(--space-xl); color: var(--text-muted); }
.shr-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.shr-thead-row { border-bottom: 1px solid var(--border); color: var(--text-muted); font-size: var(--fs-sm); }
.shr-th { text-align: left; padding: 6px; }
.shr-th-center { text-align: center; padding: 6px; }
.shr-tr { border-bottom: 1px solid var(--border); }
.shr-td-name { padding: 6px; font-weight: 500; }
.shr-td-sec { padding: 6px; color: var(--text-muted); font-size: var(--fs-sm); }
.shr-td-center { text-align: center; padding: 6px; }
.shr-td-actions { text-align: right; padding: 6px; }
.shr-check-ok { color: var(--success); }
.shr-check-no { color: var(--text-muted); }
.shr-form-section { border-top: 1px solid var(--border); padding-top: 10px; margin-top: var(--space-sm); }
.shr-form-title { font-size: 13px; margin-bottom: 6px; }
.shr-form-row { display: flex; gap: var(--space-sm); flex-wrap: wrap; align-items: center; }
.shr-input-group { display: flex; gap: 0; align-items: center; }
.shr-input-group-btn { border-radius: 0 var(--r-sm) var(--r-sm) 0; margin-left: -1px; }
.shr-checkbox-label { font-size: var(--fs-sm); display: flex; align-items: center; gap: var(--space-xs); }
.shr-error { color: var(--danger); }
.shr-dir-row { display: flex; align-items: center; gap: 6px; margin-bottom: var(--space-xs); }
.shr-btn-row { display: flex; gap: var(--space-sm); margin-top: var(--space-sm); }
.shr-label { font-size: var(--fs-sm); font-weight: 500; }
.shr-toggle { display: flex; align-items: center; gap: var(--space-sm); cursor: pointer; }
.shr-toggle-text { font-size: 13px; }
.shr-pw-section { margin-top: 14px; border-top: 1px solid var(--border); padding-top: var(--space-md); }
.shr-pw-row { display: flex; gap: var(--space-sm); align-items: center; flex-wrap: wrap; margin-top: 6px; }
.shr-badge-loading { background: rgba(100, 100, 100, .12); color: var(--text-muted); }
.shr-badge-warn { background: rgba(234, 179, 8, .12); color: var(--warning); }
.shr-badge-err { background: rgba(239, 68, 68, .12); color: var(--danger); }
.shr-dirs { margin: 6px 0; }
.shr-muted { color: var(--text-muted); }
.shr-note { font-size: var(--fs-sm); color: var(--text-muted); margin-top: var(--space-sm); }
.shr-icon-warn { color: var(--warning); }
.shr-form-row-inline { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; margin-bottom: var(--space-sm); }
.shr-dlna-form { display: flex; flex-direction: column; gap: var(--space-sm); }
.shr-dlna-stats { display: flex; gap: var(--space-lg); flex-wrap: wrap; margin-bottom: var(--space-md); padding: var(--space-sm) var(--space-md); background: var(--overlay-1); border-radius: var(--r-md); font-size: var(--fs-sm); }
.shr-dlna-stat { display: flex; align-items: center; gap: var(--space-xs); color: var(--text-muted); }
.shr-dlna-stat i { color: var(--accent); }
.shr-dlna-drives { display: flex; flex-direction: column; gap: 2px; margin: var(--space-xs) 0; }
.shr-dlna-drive { padding: var(--space-xs) 0; }
.shr-dlna-drv-check { display: flex; align-items: center; gap: var(--space-sm); cursor: pointer; font-size: 13px; }
.shr-dlna-types { display: inline-flex; gap: 3px; margin-left: var(--space-sm); }
.shr-dlna-type-tag { padding: 1px 7px; font-size: 11px; font-weight: 600; border: 1px solid var(--border); border-radius: var(--r-sm); background: transparent; cursor: pointer; color: var(--text-muted); transition: all .15s; }
.shr-dlna-type-tag.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.shr-dlna-ctypes { display: inline-flex; gap: 3px; margin-left: var(--space-sm); }
.shr-dlna-toggle-label { display: flex; align-items: center; gap: var(--space-sm); cursor: pointer; font-size: 13px; }

/* ── Easy Share Wizard ── */
.esh-sidebar-sep { border-top: 1px solid var(--border); margin: 6px 12px; }
.esh-step-bar { display: flex; align-items: center; justify-content: center; padding: 16px 8px; margin-bottom: 8px; border-bottom: 1px solid var(--border); gap: 0; }
.esh-step { display: flex; align-items: center; gap: 5px; }
.esh-step-num { width: 26px; height: 26px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; background: var(--overlay-1); color: var(--text-muted); flex-shrink: 0; }
.esh-step-active .esh-step-num { background: var(--accent); color: #fff; }
.esh-step-done .esh-step-num { background: var(--success); color: #fff; }
.esh-step-label { font-size: 12px; color: var(--text-muted); white-space: nowrap; }
.esh-step-active .esh-step-label { color: var(--text); font-weight: 600; }
.esh-step-line { flex: 0 0 32px; height: 2px; background: var(--border); margin: 0 6px; }
.esh-content { padding: 4px 12px 8px; flex: 1; overflow-y: auto; }
.esh-title { font-size: 17px; font-weight: 600; margin: 0 0 4px; }
.esh-subtitle { font-size: 13px; color: var(--text-muted); margin: 0 0 14px; }
.esh-label { display: block; font-size: 13px; font-weight: 500; margin-bottom: 5px; color: var(--text-secondary); }
.esh-nav { display: flex; align-items: center; padding: 12px; border-top: 1px solid var(--border); gap: 8px; }
.esh-devices { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 10px; margin-top: 12px; }
.esh-device-card { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 18px 10px 14px; border: 2px solid var(--border); border-radius: 12px; cursor: pointer; transition: border-color .15s, background .15s; background: var(--overlay-1); user-select: none; }
.esh-device-card:hover:not(.esh-disabled) { border-color: var(--accent); background: rgba(99,102,241,.04); }
.esh-device-card.esh-selected { border-color: var(--accent); background: rgba(99,102,241,.08); box-shadow: 0 0 0 1px var(--accent); }
.esh-device-card.esh-disabled { opacity: .35; cursor: not-allowed; }
.esh-device-icon { font-size: 30px; }
.esh-device-name { font-size: 13px; font-weight: 600; }
.esh-device-proto { font-size: 11px; color: var(--text-muted); background: var(--overlay-1); padding: 1px 8px; border-radius: 10px; border: 1px solid var(--border); }
.esh-device-missing { font-size: 10px; color: var(--warning); margin-top: 2px; }
.esh-access-options { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.esh-access-card { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border: 1px solid var(--border); border-radius: 10px; cursor: pointer; background: var(--overlay-1); transition: border-color .15s; }
.esh-access-card:hover { border-color: var(--accent); }
.esh-access-info { display: flex; flex-direction: column; gap: 3px; }
.esh-access-name { font-size: 14px; font-weight: 500; display: flex; align-items: center; gap: 6px; }
.esh-access-desc { font-size: 12px; color: var(--text-muted); }
.esh-creating { display: flex; align-items: center; gap: 10px; padding: 20px 0; color: var(--text-muted); font-size: 14px; }
.esh-conn-card { border: 1px solid var(--border); border-radius: 10px; padding: 14px 16px; margin-bottom: 10px; background: var(--overlay-1); }
.esh-conn-card.esh-conn-err { border-color: var(--danger); opacity: .6; }
.esh-conn-header { font-size: 14px; font-weight: 600; margin-bottom: 10px; display: flex; align-items: center; gap: 8px; }
.esh-conn-steps { display: flex; flex-direction: column; gap: 6px; }
.esh-conn-step { font-size: 13px; display: flex; align-items: center; gap: 8px; }
.esh-conn-num { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: var(--accent); color: #fff; font-size: 11px; font-weight: 600; flex-shrink: 0; }
.esh-conn-url { display: flex; align-items: center; gap: 8px; background: var(--bg); border-radius: 8px; padding: 8px 12px; margin: 4px 0 0 28px; border: 1px solid var(--border); }
.esh-conn-url code { font-size: 13px; font-weight: 600; flex: 1; word-break: break-all; }
.esh-copy-btn { background: none; border: none; cursor: pointer; color: var(--text-muted); padding: 4px 8px; border-radius: var(--r-sm); transition: color .15s; }
.esh-copy-btn:hover { color: var(--accent); }
.esh-done-icon { font-size: 40px; color: var(--success); margin-bottom: 8px; }

/* ── Backup App: extracted inline styles ── */

.bak-icon-accent { color:var(--accent); }
.bak-hidden { display:none; }
.bak-row { display:flex; gap:6px; align-items:center; }
.bak-row-wrap { display:flex; gap:16px; align-items:center; flex-wrap:wrap; }
.bak-row-noshrink { display:flex; gap:6px; flex-shrink:0; }
.bak-row-sm { display:flex; gap:6px; }
.bak-row-between-mb { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.bak-row-end { display:flex; justify-content:flex-end; margin-bottom:8px; padding-bottom:8px; border-bottom:1px solid var(--border); position:sticky; top:0; background:var(--bg-surface); z-index:2; }
.bak-col-gap8 { display:flex; flex-direction:column; gap:8px; }
.bak-col-gap10 { display:flex; flex-direction:column; gap:10px; }
.bak-row-mb14 { display:flex; gap:8px; margin-bottom:14px; }
.bak-row-mt6-wrap { display:flex; gap:8px; margin-top:6px; flex-wrap:wrap; }
.bak-radio-label { display:flex; align-items:center; gap:8px; margin-bottom:6px; cursor:pointer; }
.bak-radio-label-last { display:flex; align-items:center; gap:8px; cursor:pointer; }
.bak-row-gap8 { display:flex; align-items:center; gap:8px; }
.bak-row-gap8-bare { display:flex; gap:8px; }
.bak-mt8 { margin-top:8px; }
.bak-mt6 { margin-top:6px; }
.bak-mt10 { margin-top:10px; }
.bak-mt4 { margin-top:4px; }
.bak-mt12 { margin-top:12px; }
.bak-mt14 { margin-top:14px; }
.bak-mt24 { margin-top:24px; }
.bak-mb8 { margin-bottom:8px; }
.bak-m0 { margin:0; }
.bak-p16 { padding:16px; }
.bak-p0 { padding:0; }
.bak-w-auto { width:auto; }
.bak-w-full { width:100%; }
.bak-w70 { width:70px; }
.bak-w80 { width:80px; }
.bak-w120 { width:120px; }
.bak-w180 { width:180px; }
.bak-w-usb-select { min-width:200px; max-width:340px; }
.bak-fs10 { font-size:10px; }
.bak-fs24 { font-size:24px; }
.bak-text-muted { color:var(--text-muted); }
.bak-text-danger { color:#ef4444; }
.bak-text-warning { color:#f59e0b; }
.bak-text-success { color:#10b981; }
.bak-text-orange { color:#e67e22; }
.bak-text-red { color:#dc3545; }
.bak-text-gray { color:#6b7280; }
.bak-text-amber { color:#fb923c; }
.bak-fw600 { font-weight:600; }
.bak-hint { color:var(--text-muted); font-size:0.85em; }
.bak-desc-muted { color:var(--text-muted); font-size:0.82em; margin:0 0 8px; }
.bak-desc-muted-lg { color:var(--text-muted); font-size:12px; margin:0 0 14px; }
.bak-text-muted-italic { color:var(--text-muted); font-style:italic; }
.bak-text-muted-mr { color:var(--text-muted); margin-right:6px; }
.bak-text-muted-right { color:var(--text-muted); margin-left:auto; font-size:11px; }
.bak-text-muted-ml { color:var(--text-muted); margin-left:8px; font-size:11px; }
.bak-text-muted-ml8 { color:var(--text-muted); margin-left:8px; }
.bak-text-muted-mt { color:var(--text-muted); margin-top:4px; }
.bak-icon-accent-mr { color:var(--accent); margin-right:6px; }
.bak-mr4 { margin-right:4px; }
.bak-ml-auto { margin-left:auto; }
.bak-small-muted { font-size:11px; color:var(--text-muted); }
.bak-small-muted-mt { font-size:11px; color:var(--text-muted); margin-top:4px; }
.bak-small-muted-mt2 { font-size:11px; color:var(--text-muted); margin-top:2px; }
.bak-small-warning { font-size:11px; color:#f59e0b; }
.bak-small12-muted { font-size:12px; color:var(--text-muted); }
.bak-small12-muted-mt { font-size:12px; color:var(--text-muted); margin-top:2px; }
.bak-label12 { font-size:12px; font-weight:600; }
.bak-label12-block { font-size:12px; font-weight:600; display:block; margin-bottom:4px; }
.bak-heading13 { font-weight:600; font-size:13px; }
.bak-heading13-mb { font-weight:600; font-size:13px; margin-bottom:8px; }
.bak-heading13-tight { font-weight:600; font-size:13px; margin-bottom:-6px; }
.bak-fw600-accent { font-weight:600; color:var(--accent); }
.bak-optional { font-weight:400; font-size:0.85em; color:var(--text-muted); }
.bak-caption { font-size:0.82em; color:var(--text-muted); }
.bak-caption-sm { font-size:0.8em; color:var(--text-muted); }
.bak-caption-accent { font-size:0.8em; color:var(--accent); }
.bak-block-mt12 { font-size:0.9em; margin-top:12px; display:block; }
.bak-item-name { font-size:0.9em; color:var(--text); flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-weight:500; }
.bak-empty { text-align:center; padding:30px; color:var(--text-muted); }
.bak-empty-sm { text-align:center; padding:24px; color:var(--text-muted); }
.bak-empty-lg { text-align:center; padding:40px; color:var(--text-muted); }
.bak-empty-xs { text-align:center; padding:20px; color:var(--text-muted); }
.bak-empty-danger { text-align:center; padding:20px; color:#dc3545; }
.bak-empty-danger-sm { text-align:center; padding:24px; color:#dc3545; }
.bak-empty-error { padding:20px; text-align:center; color:#ef4444; }
.bak-empty-icon { font-size:48px; opacity:.3; margin-bottom:12px; display:block; }
.bak-empty-icon-sm { font-size:32px; opacity:.3; display:block; margin-bottom:10px; }
.bak-info-panel { margin-bottom:14px; padding:10px; background:var(--bg); border-radius:8px; font-size:13px; }
.bak-warn-panel { margin-top:14px; padding:10px; background:#dc354520; border-radius:8px; color:#dc3545; font-size:12px; }
.bak-info-note { margin-top:14px; padding:10px; background:var(--accent)15; border-radius:8px; font-size:12px; color:var(--text-muted); }
.bak-card-section { margin-top:12px; padding:14px; background:var(--card-bg); border:1px solid var(--border); border-radius:10px; }
.bak-input-full-mt { width:100%; margin-top:4px; }
.bak-input-confirm { width:100%; text-transform:uppercase; }
.bak-flex1 { flex:1; min-width:0; }
.bak-flex1-ellipsis { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; min-width:0; }
.bak-flex-none { flex:0 0 auto; }
.bak-flex1-mono { flex:1; font-family:monospace; font-size:0.85em; }
.bak-flex1-muted { flex:1; display:flex; align-items:center; font-size:12px; color:var(--text-muted); }
.bak-input-text { flex:1; padding:8px 12px; border-radius:8px; background:var(--bg); border:1px solid var(--border); color:var(--text); font-size:13px; }
.bak-shrink0 { flex-shrink:0; }
.bak-modal-520 { width:520px; }
.bak-modal-650 { width:650px; }
.bak-modal-620 { width:620px; }
.bak-modal-600 { width:600px; }
.bak-modal-500 { width:500px; }
.bak-modal-480 { width:480px; }
.bak-modal-460 { width:460px; }
.bak-modal-400 { width:400px; }
.bak-encrypt-warning { display:flex; align-items:flex-start; gap:8px; padding:10px 12px; background:rgba(251,146,60,0.1); border:1px solid rgba(251,146,60,0.3); border-radius:8px; color:#fb923c; font-size:0.85em; line-height:1.4; }
.bak-encrypt-warning i { font-size:1.1em; flex-shrink:0; margin-top:2px; }
.bak-encrypt-info { display:flex; align-items:flex-start; gap:8px; padding:10px 12px; background:rgba(59,130,246,0.1); border:1px solid rgba(59,130,246,0.3); border-radius:8px; color:#60a5fa; font-size:0.85em; line-height:1.4; }
.bak-encrypt-info i { font-size:1.1em; flex-shrink:0; margin-top:2px; }
.bak-mb12 { margin-bottom:12px; }
.bak-key-display { font-family:monospace; font-size:0.85em; background:var(--bg-input,#1e1e2e); border:1px solid var(--border,#333); border-radius:6px; padding:8px 10px; word-break:break-all; color:#34d399; user-select:all; cursor:text; }
.bak-progress-fill { width:0%; transition:width .3s; }
.bak-snap-progress-fill { width:0%; height:100%; background:var(--accent); border-radius:6px; transition:width .3s; }
.bak-bar-h8 { height:8px; }
.bak-bar-h6 { height:6px; width:100%; }
.bak-bar-track { background:var(--border); border-radius:6px; height:8px; overflow:hidden; }
.bak-start-area { margin-top:8px; padding:16px; background:rgba(16,185,129,0.06); border:1px solid rgba(16,185,129,0.15); border-radius:10px; display:flex; align-items:center; gap:12px; }
.bak-row-mt8 { margin-top:8px; display:flex; gap:8px; }
.bak-progress-panel { margin-bottom:16px; padding:14px; background:var(--card-bg); border-radius:10px; border:1px solid var(--border); }
.bak-progress-log { margin-top:10px; max-height:200px; overflow-y:auto; font-size:11px; color:var(--text-muted); white-space:pre-wrap; border-top:1px solid var(--border); padding-top:8px; }
.bak-scroll-body { padding:16px; overflow-y:auto; max-height:500px; }
.bak-scroll-400 { max-height:400px; overflow-y:auto; }
.bak-scroll-mono { max-height:420px; overflow-y:auto; font-size:13px; font-family:var(--font-mono, monospace); }
.bak-scroll-280 { height:280px; overflow-y:auto; padding:4px 0; }
.bak-textarea { width:100%; padding:8px 12px; border-radius:8px; background:var(--bg); border:1px solid var(--border); color:var(--text); font-size:13px; box-sizing:border-box; }
.bak-btn-danger { background:#dc3545; color:#fff; }
.bak-btn-danger-disabled { background:#dc3545; color:#fff; opacity:.5; pointer-events:none; }
.bak-section-divider { border-top:1px solid var(--border); padding-top:12px; }
.bak-gap8 { gap:8px; }
.bak-badge-orange { font-size:10px; background:#e67e22; color:#fff; }
.bak-badge-red { font-size:10px; background:#dc3545; color:#fff; }
.bak-badge-purple { font-size:10px; background:#6366f1; color:#fff; }
.bak-modal-bar { padding:10px 16px; border-bottom:1px solid var(--border); display:flex; gap:8px; align-items:center; }
.bak-list-item { display:flex; justify-content:space-between; align-items:center; padding:12px 14px; margin-bottom:6px; background:var(--bg); border-radius:8px; border:1px solid var(--border); }
.bak-list-item-sm { display:flex; justify-content:space-between; align-items:center; padding:10px 14px; margin-bottom:6px; background:var(--bg); border-radius:8px; border:1px solid var(--border); }
.bak-form-body { padding:16px; display:flex; flex-direction:column; gap:14px; }
.bak-icon-amber { color:#fb923c; font-size:1.2em; }
.bak-tag-row { margin-top:6px; display:flex; gap:4px; flex-wrap:wrap; }
.bak-backup-item { display:flex; justify-content:space-between; align-items:center; padding:12px 16px; margin-bottom:8px; background:var(--card-bg); border-radius:10px; border:1px solid var(--border); }

/* ═══ Apps.js Shared Components ═══ */

/* ── Icon colors ── */
.app-icon-heart   { color: #e74c3c; }
.app-icon-danger  { color: #ef4444; }
.app-icon-gallery { color: #ec4899; }
.app-icon-share   { color: #3b82f6; }
.app-icon-purple  { color: #a78bfa; }
.app-icon-violet  { color: var(--accent-purple); }
.app-icon-amber   { color: #f59e0b; }
.app-icon-accent  { color: var(--accent); }
.app-icon-success { color: var(--success, #22c55e); }
.app-icon-info    { color: var(--info, #3b82f6); }
.app-icon-orange  { color: #f97316; }
.app-icon-muted-sm { color: var(--text-muted); font-size: 11px; }
.app-icon-fixed   { width: 16px; text-align: center; }

/* ── Status text colors ── */
.app-text-ok     { color: #10b981; }
.app-text-warn   { color: #f59e0b; }
.app-text-danger { color: var(--danger, #ef4444); }
.app-text-error  { color: var(--error, #ef4444); }

/* ── Header icons (before modal/section titles) ── */
.app-hdr-icon { margin-right: 8px; color: var(--accent); }
.app-hdr-icon--warning { color: var(--warning, #f59e0b); }
.app-hdr-icon--success { color: #22c55e; }

/* ── Button / inline icons ── */
.app-btn-icon     { margin-right: 6px; }
.app-chevron-tiny { font-size: 9px; margin-left: 2px; }
.app-shield-icon  { color: var(--warning, #f59e0b); font-size: 11px; }
.app-pre-icon     { margin-right: 6px; opacity: .5; }
.app-os-icon      { font-size: 18px; opacity: .7; }

/* ── Empty states ── */
.app-empty { text-align: center; padding: 40px; color: var(--text-muted); }
.app-empty--sm      { padding: 30px; }
.app-empty--compact { text-align: center; padding: 16px; color: var(--text-muted); }
.app-empty--error   { color: #ef4444; }
.app-empty--loading { text-align: center; padding: 20px; color: var(--text-secondary); }
.app-empty-icon     { font-size: 48px; opacity: .3; margin-bottom: 16px; display: block; }

/* ── Spinners ── */
.app-spinner-lg { font-size: 32px; }
.app-spinner-md { font-size: 24px; }

/* ── Spacing utilities ── */
.app-mt-xs  { margin-top: 4px; }
.app-mt-sm  { margin-top: 8px; }
.app-mt-md  { margin-top: 12px; }
.app-mt-lg  { margin-top: 16px; }
.app-mb-md  { margin-bottom: 12px; }
.app-ml-0   { margin-left: 0; }
.app-ml-md  { margin-left: 12px; }
.app-ml-auto { margin-left: auto; }
.app-mr-auto { margin-right: auto; }
.app-p-md   { padding: 16px; }
.app-gap-md { gap: 10px; }

/* ── Text styles ── */
.app-text-2xs    { font-size: 10px; }
.app-text-xs     { font-size: 11px; }
.app-text-sm     { font-size: 12px; }
.app-text-center { text-align: center; }
.app-sublabel    { font-size: 11px; color: var(--text-muted); margin-bottom: 4px; }
.app-label-muted { color: var(--text-muted); font-size: 12px; }
.app-path        { color: var(--accent); font-size: 13px; }
.app-filename    { font-size: 13px; word-break: break-all; }
.app-title-sm    { font-weight: 600; font-size: 13px; }
.app-stat-value  { font-size: 20px; font-weight: 600; }
.app-stat-hero   { font-size: 24px; font-weight: 700; color: var(--accent); }
.app-stat-hero-lg { font-size: 24px; }
.app-detail-center { font-size: 12px; color: var(--text-muted); text-align: center; }
.app-model-text  { color: #94a3b8; font-style: italic; font-size: 11px; }
.app-nowrap      { white-space: nowrap; }
.app-w-full      { width: 100%; }

/* ── Hint / note / description ── */
.app-hint { margin-top: 8px; font-size: 11px; color: var(--text-muted); }
.app-note { margin-bottom: 10px; font-size: 12px; color: var(--text-muted); }
.app-note--accent { color: var(--accent); }
.app-desc { margin-bottom: 12px; font-size: 13px; color: var(--text-secondary); }
.app-error-text { color: #ef4444; font-size: 12px; display: none; }

/* ── Flex layouts ── */
.app-row         { display: flex; gap: 8px; align-items: center; }
.app-row-wrap    { display: flex; gap: 8px; flex-wrap: wrap; }
.app-row-between { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.app-summary-row { display: flex; align-items: center; gap: 20px; flex-wrap: wrap; }
.app-stats-row   { display: flex; gap: 24px; justify-content: center; margin: 16px 0; }
.app-actions     { display: flex; gap: 10px; margin-top: 16px; }
.app-flex-1      { flex: 1; }
.app-flex-col    { flex: 1; display: flex; flex-direction: column; }
.app-flex-fill   { flex: 1; min-height: 0; }
.app-flex-fill-200 { flex: 1; min-width: 200px; }
.app-justify-center { justify-content: center; }
.app-toolbar-actions { margin-left: auto; display: flex; gap: 6px; }
.app-toolbar-flat { border: none; padding: 8px 0; }

/* ── Stat / info blocks ── */
.app-stat-block { text-align: center; min-width: 100px; }

/* ── List & items ── */
.app-list-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--border); }
.app-divider  { height: 1px; background: var(--border); margin: 4px 0; }
.app-chip-list { display: flex; flex-wrap: wrap; gap: 8px; }
.app-chip { display: flex; align-items: center; gap: 6px; padding: 6px 12px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-sm); font-size: 12px; }
.app-dot  { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ── Context menu ── */
.app-ctx-btn { display: flex; align-items: center; gap: 8px; width: 100%; padding: 8px 16px; background: none; border: none; cursor: pointer; font-size: 13px; text-align: left; transition: background 0.15s; }
.app-ctx-btn:hover { background: rgba(255,255,255,0.06); }

/* ── Modal sizes ── */
.app-modal-sm { max-width: 420px; }
.app-modal-md { max-width: 480px; }
.app-modal-lg { max-width: 500px; }

/* ── Confirm dialog ── */
.app-confirm-icon  { font-size: 32px; color: #ef4444; margin-bottom: 8px; display: block; }
.app-confirm-title { font-size: 16px; }

/* ── Table column widths ── */
.app-col-icon       { width: 36px; }
.app-col-sm         { width: 60px; }
.app-col-actions-xs { width: 80px; }
.app-col-actions-sm { width: 120px; }
.app-col-actions-md { width: 140px; }
.app-col-actions    { width: 150px; }
.app-col-actions-lg { width: 180px; }

/* ── Input groups ── */
.app-input-group  { display: flex; align-items: center; gap: 0; }
.app-input-prefix { border-radius: var(--r-sm) 0 0 var(--r-sm); border-right: none; }
.app-input-suffix { padding: 8px 12px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: 0 var(--r-sm) var(--r-sm) 0; font-size: 13px; color: var(--text-muted); white-space: nowrap; }
.app-input-full   { width: 100%; box-sizing: border-box; }
.app-input-narrow { max-width: 100px; }
.app-mono-input   { flex: 1; font-family: monospace; font-size: 12px; }

/* ── Info / scroll boxes ── */
.app-info-box   { margin-bottom: 14px; padding: 10px 14px; background: var(--bg-surface); border-radius: var(--r-sm); border: 1px solid var(--border); }
.app-scroll-box { max-height: 180px; overflow-y: auto; margin-bottom: 16px; background: var(--bg-input, var(--bg-surface)); border-radius: var(--r-sm); padding: 8px 12px; }
.app-user-list  { display: none; margin-top: 6px; padding: 8px; background: var(--bg-secondary); border-radius: 8px; max-height: 140px; overflow-y: auto; }

/* ── Form labels ── */
.app-form-label { font-size: 12px; color: var(--text-secondary); margin-bottom: 4px; display: block; }
.app-form-label-inline { font-size: 12px; color: var(--text-secondary); }
.app-label-row { margin-bottom: 6px; display: flex; align-items: center; gap: 6px; }

/* ── Checkbox labels ── */
.app-check-label { display: flex; align-items: center; gap: 6px; padding: 3px 0; font-size: 13px; cursor: pointer; }
.app-check-label--secondary { gap: 8px; color: var(--text-secondary); }
.app-check-label--center { gap: 8px; justify-content: center; }
.app-checkbox { accent-color: var(--accent); width: 16px; height: 16px; }

/* ── Player ── */
.app-player-wrap { display: flex; align-items: center; justify-content: center; height: 100%; padding: 20px; }

/* ── Links ── */
.app-link-sm { color: #3b82f6; text-decoration: none; font-size: 11px; }

/* ── Analysis chart ── */
.app-bar-track  { display: flex; height: 22px; border-radius: 6px; overflow: hidden; background: rgba(255,255,255,.05); }
.app-bar-other  { flex: 1; background: rgba(255,255,255,.1); }
.app-legend     { display: flex; flex-wrap: wrap; gap: 8px 14px; margin-top: 6px; }
.app-legend-item { font-size: 11px; color: var(--text-muted); display: flex; align-items: center; gap: 4px; }
.app-swatch     { width: 8px; height: 8px; border-radius: 2px; display: inline-block; }
.app-crumb-sep  { color: var(--text-muted); margin: 0 2px; }
.app-file-subpath { font-size: 10px; color: var(--text-muted); margin-top: 1px; }

/* ── FM specific overrides ── */
.fm-main-flex { flex: 1; display: flex; flex-direction: column; overflow: hidden; position: relative; }
.fm-ana-overlay { position: absolute; inset: 0; background: var(--bg-surface); z-index: 10; overflow-y: auto; }
.fm-toolbar-btn-compact { width: auto; padding: 4px 10px; font-size: 12px; white-space: nowrap; }

/* ── Docker specific ── */
.dkr-modal-body-flex { display: flex; flex-direction: column; gap: 8px; padding: 8px; }
.dkr-modal-body-form { padding: 16px; display: flex; flex-direction: column; gap: 12px; }
.dkr-btn-file { font-size: 12px; padding: 4px 10px; margin: 0; cursor: pointer; }
.dkr-compose-flex { min-height: 300px; flex: 1; }
.dkr-logs-btn {
    background: none; border: 1px solid rgba(139,92,246,0.3); color: #a78bfa;
    border-radius: var(--r-sm); padding: 4px 8px; cursor: pointer; font-size: 12px;
    transition: all var(--transition);
}
.dkr-logs-btn:hover { background: rgba(139,92,246,0.15); color: #c4b5fd; }
.dkr-compose-editor {
    background: #1e1e2e; color: #cdd6f4; font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.dkr-env-masked { color: var(--text-muted); font-style: italic; cursor: pointer; }
.dkr-env-masked:hover { color: var(--text-primary); }
.dkr-env-reveal-btn {
    background: none; border: none; color: var(--text-muted); cursor: pointer;
    font-size: 11px; padding: 1px 4px; border-radius: 3px; margin-left: 4px;
}
.dkr-env-reveal-btn:hover { color: var(--text-primary); background: rgba(255,255,255,0.05); }
.dkr-yaml-status {
    font-size: 11px; padding: 2px 8px; border-radius: 10px; display: inline-flex;
    align-items: center; gap: 4px; font-weight: 500;
}
.dkr-yaml-status.valid { background: rgba(34,197,94,0.15); color: var(--success); }
.dkr-yaml-status.invalid { background: rgba(239,68,68,0.15); color: var(--danger); }
.dkr-yaml-status.unchecked { background: rgba(148,163,184,0.15); color: var(--text-muted); }
.dkr-warn-banner {
    background: rgba(245,158,11,0.1); border: 1px solid rgba(245,158,11,0.3);
    color: var(--warning); border-radius: var(--r-sm); padding: 8px 12px;
    font-size: 12px; display: flex; align-items: flex-start; gap: 8px;
}
.dkr-warn-banner i { margin-top: 2px; flex-shrink: 0; }
.dkr-readonly-notice {
    background: rgba(148,163,184,0.1); border: 1px solid rgba(148,163,184,0.2);
    color: var(--text-muted); border-radius: var(--r-sm); padding: 6px 12px;
    font-size: 12px; display: flex; align-items: center; gap: 6px;
}


/* ── Docker Manager layout ── */
.dkr { display: flex; height: 100%; overflow: hidden; background: var(--bg-base); }
.dkr-sidebar {
    width: 180px; flex-shrink: 0; background: var(--bg-primary);
    border-right: 1px solid var(--border); display: flex; flex-direction: column;
    padding: 8px 0; gap: 2px; overflow-y: auto;
}
.dkr-nav-item {
    display: flex; align-items: center; gap: 10px; padding: 8px 16px;
    color: var(--text-muted); cursor: pointer; font-size: 13px; font-weight: 500;
    border-radius: 0; transition: all var(--transition); white-space: nowrap;
}
.dkr-nav-item:hover { background: var(--bg-hover); color: var(--text-primary); }
.dkr-nav-item.active { background: rgba(99,102,241,0.15); color: var(--accent); border-right: 2px solid var(--accent); }
.dkr-nav-item i { width: 16px; text-align: center; }
.dkr-main { flex: 1; display: flex; flex-direction: column; overflow: hidden; }
.dkr-cnt-count { font-size: 11px; opacity: 0.7; margin-left: auto; }

/* ── Docker toolbar ── */
.dkr-toolbar {
    display: flex; align-items: center; gap: 8px; padding: 10px 14px;
    background: var(--bg-primary); border-bottom: 1px solid var(--border); flex-shrink: 0;
}
.dkr-toolbar-title { font-size: 14px; font-weight: 600; color: var(--text-primary); display: flex; align-items: center; gap: 8px; }
.dkr-badge {
    background: rgba(99,102,241,0.2); color: var(--accent); font-size: 11px;
    padding: 1px 7px; border-radius: 10px; font-weight: 600;
}
.dkr-filter {
    background: var(--bg-base); border: 1px solid var(--border); color: var(--text-primary);
    border-radius: var(--r-sm); padding: 4px 10px; font-size: 12px; width: 180px;
}
.dkr-filter:focus { outline: none; border-color: var(--accent); }
.dkr-select {
    background: var(--bg-base); border: 1px solid var(--border); color: var(--text-primary);
    border-radius: var(--r-sm); padding: 3px 8px; font-size: 12px; cursor: pointer;
}
.dkr-check { display: flex; align-items: center; gap: 5px; font-size: 12px; color: var(--text-muted); cursor: pointer; }
.dkr-btn {
    background: var(--bg-base); border: 1px solid var(--border); color: var(--text-primary);
    border-radius: var(--r-sm); padding: 4px 10px; font-size: 12px; cursor: pointer;
    transition: all var(--transition); white-space: nowrap;
}
.dkr-btn:hover { background: var(--bg-hover); border-color: var(--accent); color: var(--accent); }
.dkr-btn.primary { background: var(--accent); border-color: var(--accent); color: #fff; }
.dkr-btn.primary:hover { opacity: 0.85; }
.dkr-btn.danger { background: rgba(239,68,68,0.1); border-color: rgba(239,68,68,0.4); color: var(--danger); }
.dkr-btn.danger:hover { background: rgba(239,68,68,0.2); }
.dkr-btn.success { background: rgba(34,197,94,0.1); border-color: rgba(34,197,94,0.4); color: var(--success); }
.dkr-btn.warning { background: rgba(234,179,8,0.1); border-color: rgba(234,179,8,0.4); color: var(--warning); }
.dkr-btn.info { background: rgba(6,182,212,0.1); border-color: rgba(6,182,212,0.4); color: #06b6d4; }
.dkr-refresh { margin-left: auto; }

/* ── Docker table ── */
.dkr-table-wrap { flex: 1; overflow-y: auto; }
.dkr-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.dkr-table th { background: var(--bg-primary); color: var(--text-muted); font-weight: 600; padding: 7px 10px; text-align: left; border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 1; }
.dkr-table td { padding: 7px 10px; border-bottom: 1px solid rgba(148,163,184,0.08); vertical-align: middle; }
.dkr-table-compact td, .dkr-table-compact th { padding: 4px 8px; }
.dkr-row:hover td { background: var(--bg-hover); }
.dkr-link { color: var(--accent); cursor: pointer; font-weight: 500; }
.dkr-link:hover { text-decoration: underline; }
.dkr-ellipsis { max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dkr-muted { color: var(--text-muted); font-size: 11px; }
.dkr-status-text { font-size: 11px; font-weight: 500; }
.dkr-actions { display: flex; gap: 4px; align-items: center; }
.dkr-act-btn {
    background: none; border: 1px solid var(--border); color: var(--text-muted);
    border-radius: var(--r-sm); padding: 3px 7px; font-size: 11px; cursor: pointer;
    transition: all var(--transition);
}
.dkr-act-btn:hover { background: var(--bg-hover); color: var(--text-primary); border-color: var(--accent); }
.dkr-act-btn.success { border-color: rgba(34,197,94,0.3); color: var(--success); }
.dkr-act-btn.success:hover { background: rgba(34,197,94,0.1); }
.dkr-act-btn.warning { border-color: rgba(234,179,8,0.3); color: var(--warning); }
.dkr-act-btn.warning:hover { background: rgba(234,179,8,0.1); }
.dkr-act-btn.danger { border-color: rgba(239,68,68,0.3); color: var(--danger); }
.dkr-act-btn.danger:hover { background: rgba(239,68,68,0.1); }
.dkr-act-btn.info { border-color: rgba(6,182,212,0.3); color: #06b6d4; }
.dkr-act-btn.info:hover { background: rgba(6,182,212,0.1); }
.dkr-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--text-muted); flex-shrink: 0; }
.dkr-dot.running { background: var(--success); box-shadow: 0 0 4px var(--success); }
.dkr-dot.exited, .dkr-dot.stopped { background: var(--danger); }
.dkr-dot.paused { background: var(--warning); }
.dkr-dot.restarting { background: #06b6d4; }
.dkr-project-badge { background: rgba(99,102,241,0.15); color: var(--accent); font-size: 10px; padding: 1px 6px; border-radius: 8px; }
.dkr-tag { background: rgba(148,163,184,0.15); color: var(--text-muted); font-size: 11px; padding: 1px 6px; border-radius: 8px; font-family: monospace; }
.dkr-port-badge { background: rgba(6,182,212,0.12); color: #06b6d4; font-size: 10px; padding: 1px 5px; border-radius: 6px; font-family: monospace; }
.dkr-port-link { color: #06b6d4; font-size: 11px; text-decoration: none; font-family: monospace; }
.dkr-port-link:hover { text-decoration: underline; }

/* ── Docker detail view ── */
.dkr-back { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 13px; padding: 4px 8px; border-radius: var(--r-sm); }
.dkr-back:hover { color: var(--text-primary); background: var(--bg-hover); }
.dkr-detail-title { font-size: 14px; font-weight: 600; color: var(--text-primary); display: flex; align-items: center; gap: 8px; }
.dkr-detail-tabs { display: flex; gap: 4px; margin-left: auto; }
.dkr-tab-btn {
    background: none; border: 1px solid var(--border); color: var(--text-muted);
    border-radius: var(--r-sm); padding: 4px 12px; font-size: 12px; cursor: pointer;
    transition: all var(--transition);
}
.dkr-tab-btn:hover { color: var(--text-primary); background: var(--bg-hover); }
.dkr-tab-btn.active { background: rgba(99,102,241,0.15); color: var(--accent); border-color: var(--accent); }
.dkr-detail-body { flex: 1; overflow-y: auto; padding: 12px 14px; }
.dkr-loading, .dkr-empty {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    height: 200px; color: var(--text-muted); gap: 10px; font-size: 13px;
}

/* ── Docker logs ── */
.dkr-logs-toolbar { display: flex; align-items: center; gap: 6px; padding: 6px 0; margin-bottom: 6px; flex-wrap: wrap; }
.dkr-logs {
    background: #0d1117; color: #e6edf3; font-family: 'JetBrains Mono', 'Fira Code', monospace;
    font-size: 11px; line-height: 1.6; padding: 10px; border-radius: var(--r-sm);
    overflow-y: auto; max-height: calc(100% - 48px); white-space: pre-wrap; word-break: break-all;
}

/* ── Docker inspect ── */
.dkr-inspect { display: flex; flex-direction: column; gap: 12px; }
.dkr-inspect-section { background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 12px; }
.dkr-inspect-section h3 { font-size: 12px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 8px; }
.dkr-kv { display: grid; grid-template-columns: 140px 1fr; gap: 4px 12px; font-size: 12px; }
.dkr-kv span:first-child { color: var(--text-muted); }
.dkr-kv span:last-child { color: var(--text-primary); font-family: monospace; word-break: break-all; }
.dkr-env-list { display: flex; flex-direction: column; gap: 3px; font-size: 11px; font-family: monospace; }

/* ── Docker stats grid ── */
.dkr-stats-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 10px; }
.dkr-stat-card {
    background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--r-sm);
    padding: 12px; display: flex; flex-direction: column; gap: 4px;
}
.dkr-stat-icon { font-size: 20px; color: var(--accent); opacity: 0.8; }
.dkr-stat-label { font-size: 11px; color: var(--text-muted); font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em; }
.dkr-stat-value { font-size: 22px; font-weight: 700; color: var(--text-primary); line-height: 1.2; }
.dkr-stat-sub { font-size: 11px; color: var(--text-muted); }

/* ── Docker projects ── */
.dkr-projects { flex: 1; overflow-y: auto; padding: 10px 14px; display: flex; flex-direction: column; gap: 8px; }
.dkr-project-card { background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--r-sm); overflow: hidden; transition: border-color var(--transition); }
.dkr-project-card:hover { border-color: rgba(99,102,241,0.3); }
.dkr-project-header { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.dkr-project-info { display: flex; flex-direction: column; gap: 3px; flex: 1; min-width: 0; }
.dkr-project-name { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.dkr-project-status { font-size: 11px; font-weight: 500; }
.dkr-project-status.success { color: var(--success); }
.dkr-project-status.warning { color: var(--warning); }
.dkr-project-status.muted { color: var(--text-muted); }
.dkr-project-actions { display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.dkr-project-containers { padding: 6px 12px; display: flex; flex-direction: column; gap: 4px; }
.dkr-project-ct { display: flex; align-items: center; gap: 8px; font-size: 12px; padding: 3px 0; }
.dkr-ct-name { color: var(--text-primary); font-weight: 500; min-width: 120px; }
.dkr-ct-ports { display: flex; gap: 4px; flex-wrap: wrap; }
.dkr-delete-proj-btn { background: none; border: 1px solid rgba(239,68,68,0.3); color: var(--danger); border-radius: var(--r-sm); padding: 3px 7px; font-size: 11px; cursor: pointer; }
.dkr-delete-proj-btn:hover { background: rgba(239,68,68,0.1); }
.dkr-compose-btn, .dkr-proj-create, .dkr-proj-filter, .dkr-proj-refresh { }

/* ── Docker system tab ── */
.dkr-system { padding: 12px 14px; overflow-y: auto; }
.dkr-sys-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 12px; }
.dkr-sys-card { background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 14px; }
.dkr-sys-card-title { font-size: 12px; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 10px; }
.dkr-sys-big-num { font-size: 32px; font-weight: 700; color: var(--text-primary); line-height: 1; margin: 4px 0; }
.dkr-sys-row { display: flex; align-items: center; gap: 8px; font-size: 12px; padding: 3px 0; }
.dkr-sys-label { font-size: 11px; font-weight: 500; }
.dkr-sys-label.success { color: var(--success); }
.dkr-sys-label.warning { color: var(--warning); }
.dkr-sys-label.muted { color: var(--text-muted); }

/* ── Docker modals ── */
.dkr-modal-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 1000;
    display: flex; align-items: center; justify-content: center;
}
.dkr-modal {
    background: var(--bg-primary); border: 1px solid var(--border); border-radius: 8px;
    width: 560px; max-width: 95vw; max-height: 85vh; display: flex; flex-direction: column;
    box-shadow: var(--shadow-sm);
}
.dkr-modal-logs {
    background: var(--bg-primary); border: 1px solid var(--border); border-radius: 8px;
    width: 780px; max-width: 95vw; max-height: 85vh; display: flex; flex-direction: column;
    box-shadow: var(--shadow-sm);
}
.dkr-modal-header { display: flex; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); gap: 10px; flex-shrink: 0; }
.dkr-modal-header h3 { flex: 1; font-size: 14px; font-weight: 600; color: var(--text-primary); margin: 0; }
.dkr-modal-close { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 16px; padding: 2px 6px; border-radius: var(--r-sm); }
.dkr-modal-close:hover { color: var(--text-primary); background: var(--bg-hover); }
.dkr-modal-body { padding: 16px; overflow-y: auto; flex: 1; }
.dkr-modal-footer { display: flex; gap: 8px; justify-content: flex-end; padding: 12px 16px; border-top: 1px solid var(--border); flex-shrink: 0; }
.dkr-plogs {
    flex: 1; overflow-y: auto; background: #0d1117; color: #e6edf3;
    font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 11px;
    line-height: 1.6; padding: 10px; white-space: pre-wrap; word-break: break-all;
}
.dkr-plogs-close, .dkr-plogs-follow, .dkr-plogs-lines, .dkr-plogs-refresh, .dkr-plogs-search, .dkr-plogs-service { }
.dkr-create-cancel, .dkr-create-close, .dkr-create-content, .dkr-create-file,
.dkr-create-file-label, .dkr-create-name, .dkr-create-save { }
.dkr-compose-cancel, .dkr-compose-close, .dkr-compose-save, .dkr-compose-text { }
.dkr-img-body, .dkr-img-count, .dkr-img-filter, .dkr-img-prune, .dkr-img-refresh { }
.dkr-log-follow, .dkr-log-lines, .dkr-log-refresh, .dkr-log-search { }
.dkr-vol-prune { }

/* ── App Store specific ── */
.as-modal-body-form { padding: 20px; display: flex; flex-direction: column; gap: 14px; }

/* ═══ Downloads App ═══ */

/* Layout */
.dl-layout-row { flex-direction:row; }
.dl-main-panel { flex:1; display:flex; flex-direction:column; overflow:hidden; min-height:0; }
.dl-row { display:flex; align-items:center; gap:var(--space-sm); }
.dl-key-input-row { display:flex; gap:var(--space-sm); flex:1; }
.dl-pkg-actions { display:flex; gap:var(--space-xs); align-items:center; }
.dl-section-gap { margin-top:var(--space-2xl); }
.dl-section-divider { margin-top:var(--space-lg); padding-top:var(--space-lg); border-top:1px solid var(--border); }
.dl-save-wrap { margin-top:var(--space-xl); }
.dl-extract-opts { padding-left:var(--space-2xl); margin-top:var(--space-sm); }

/* Sidebar navigation */
.dlm-sidebar { width:180px; min-width:180px; background:var(--bg-secondary); border-right:1px solid var(--border); display:flex; flex-direction:column; padding:var(--space-sm) 0; flex-shrink:0; transition:width 0.2s; }
.dlm-nav { padding:var(--space-sm) var(--space-lg); cursor:pointer; display:flex; align-items:center; gap:var(--space-sm); font-size:var(--fs-sm); color:var(--text-secondary); transition:all 0.15s; border-left:3px solid transparent; overflow:hidden; white-space:nowrap; }
.dlm-nav:hover { background:var(--bg-hover); color:var(--text-primary); }
.dlm-nav.active { background:var(--bg-hover); color:var(--accent); border-left-color:var(--accent); font-weight:600; }
.dlm-nav i { width:16px; text-align:center; font-size:var(--fs-xs); flex-shrink:0; }
.dlm-nav-badge { font-size:10px; font-weight:700; background:var(--accent); color:#fff; border-radius:10px; padding:1px 6px; margin-left:auto; min-width:18px; text-align:center; line-height:1.4; }
.dlm-nav-badge.dlm-badge-success { background:var(--success); }
.dlm-nav-badge.dlm-badge-danger { background:var(--danger); }

/* Stats panel */
.dlm-stats-panel { padding:var(--space-lg); font-size:var(--fs-xs); color:var(--text-muted); border:1px solid var(--border); border-radius:var(--r-lg); background:var(--bg-secondary); display:flex; flex-direction:column; gap:var(--space-md); width:100%; margin:var(--space-md); box-sizing:border-box; }
.dlm-stats-header { display:flex; align-items:center; justify-content:space-between; gap:var(--space-sm); }
.dlm-stats-title { font-size:var(--fs-xs); color:var(--text-secondary); font-weight:600; display:flex; align-items:center; gap:var(--space-xs); }
.dlm-stats-bar-row { display:flex; flex-wrap:wrap; gap:var(--space-xs); margin-top:var(--space-xs); color:var(--text-secondary); }
.dlm-stats-chip { background:rgba(255,255,255,0.06); border:1px solid var(--border); border-radius:var(--r-md); padding:var(--space-xs) var(--space-sm); color:var(--text-primary); font-weight:600; font-size:11px; white-space:nowrap; }
.dlm-stats-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-xs); }
.dlm-stat-box { background:var(--bg-hover); border:1px solid var(--border); border-radius:var(--r-sm); padding:var(--space-xs) var(--space-sm); }
.dlm-stat-label { color:var(--text-muted); font-size:10px; text-transform:uppercase; letter-spacing:.4px; }
.dlm-stat-value { color:var(--text-primary); font-weight:600; font-size:var(--fs-xs); margin-top:2px; word-break:break-all; }
.dlm-stat-counts { display:flex; flex-wrap:wrap; gap:var(--space-xs); }
.dlm-stat-pill { border-radius:var(--r-md); padding:var(--space-xs) var(--space-sm); font-weight:600; font-size:11px; border:1px solid var(--border); background:var(--bg-hover); color:var(--text-secondary); display:flex; align-items:center; gap:var(--space-xs); }
.dlm-stat-pill.success { color:var(--success); border-color:rgba(34,197,94,0.4); background:rgba(34,197,94,0.08); }
.dlm-stat-pill.danger { color:var(--danger); border-color:rgba(239,68,68,0.35); background:rgba(239,68,68,0.06); }
.dlm-stat-pill.muted { color:var(--text-muted); }

/* Speed chart */
.dlm-speed-chart { border:1px solid var(--border); border-radius:var(--r-sm); padding:var(--space-xs) var(--space-sm); display:flex; flex-direction:column; gap:var(--space-xs); background:var(--bg-hover); }
.dlm-chart-header, .dlm-chart-footer { display:flex; align-items:center; justify-content:space-between; font-size:10px; color:var(--text-muted); }
.dlm-chart-title { color:var(--text-secondary); font-weight:600; font-size:11px; display:flex; align-items:center; gap:var(--space-xs); }
.dlm-chart-footer span { white-space:nowrap; }
.dlm-speed-chart svg { width:100%; height:48px; }

/* Drag & drop */
.dlm-draggable { cursor:grab; }
.dlm-draggable:active { cursor:grabbing; }
.dlm-item.dlm-drag-over-top { border-top:2px solid var(--accent); transition:border-top 0.1s; }
.dlm-item.dlm-drag-over-bottom { border-bottom:2px solid var(--accent); transition:border-bottom 0.1s; }
.dlm-item.dlm-dragging { opacity:0.5; background:rgba(255,255,255,0.05); }

/* History toolbar */
.dlm-hist-toolbar { padding:var(--space-md); background:var(--bg-secondary); border-bottom:1px solid var(--border); display:flex; flex-direction:column; gap:var(--space-sm); }
.dlm-hist-row { display:flex; align-items:center; gap:var(--space-sm); flex-wrap:wrap; }
.dlm-input-sm, .dlm-select-sm { background:var(--bg-input, var(--bg-primary)); border:1px solid var(--border); border-radius:var(--r-sm); padding:var(--space-xs) var(--space-sm); color:var(--text-primary); font-size:var(--fs-sm); height:32px; }
.dlm-input-sm:focus, .dlm-select-sm:focus { outline:none; border-color:var(--accent); }
.dlm-spacer { flex:1; }
.dlm-pagination-info { font-size:var(--fs-sm); color:var(--text-secondary); margin:0 var(--space-sm); }

/* Category management */
.dlm-categories-list { display:flex; flex-direction:column; gap:var(--space-sm); margin-top:var(--space-sm); }
.dlm-category-item { background:var(--bg-hover); border:1px solid var(--border); border-radius:var(--r-sm); padding:var(--space-sm); display:flex; flex-direction:column; gap:var(--space-xs); }
.dlm-cat-header { display:flex; align-items:center; justify-content:space-between; gap:var(--space-sm); }
.dlm-cat-name { font-weight:600; font-size:var(--fs-sm); color:var(--text-primary); }
.dlm-cat-exts { font-size:11px; color:var(--text-secondary); word-break:break-all; }
.dlm-cat-path { font-size:11px; color:var(--text-muted); display:flex; align-items:center; gap:var(--space-xs); }
.dlm-cat-actions { display:flex; align-items:center; gap:var(--space-xs); }
.dlm-cat-edit-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-sm); margin-top:var(--space-sm); }
.dlm-cat-edit-field { grid-column:1/-1; }
.dlm-cat-edit-label { font-size:11px; color:var(--text-muted); display:block; margin-bottom:var(--space-xs); }
.dlm-cat-edit-input { width:100%; }
.dlm-cat-edit-picker { display:flex; gap:var(--space-xs); }
.dlm-cat-edit-picker input { flex:1; }
.dlm-cat-edit-actions { grid-column:1/-1; display:flex; justify-content:flex-end; gap:var(--space-xs); margin-top:var(--space-xs); }

/* Icon utilities */
.dl-icon-label { margin-right:var(--space-xs); }
.dl-icon-mr { margin-right:var(--space-sm); }
.dl-icon-blue { color:var(--accent); }
.dl-icon-purple { color:#a855f7; }
.dl-icon-amber { color:var(--accent-orange); }
.dl-icon-violet { color:var(--accent-purple); }
.dl-icon-success { color:var(--success); }
.dl-icon-danger { color:var(--danger); }
.dl-icon-cancelled { color:var(--text-muted); }
.dl-icon-indigo { color:#a78bfa; }
.dl-icon-torrent-sm { color:#a78bfa; font-size:10px; margin-right:3px; }
.dl-icon-torrent { color:#a78bfa; font-size:var(--fs-xs); margin-right:var(--space-xs); }
.dl-pkg-icon { color:var(--accent-orange); font-size:var(--fs-md); }
.dl-icon-extract { color:var(--accent-purple); font-size:var(--fs-base); }

/* File type icon circle backgrounds */
.dlm-ftype-video .dlm-item-icon { background:rgba(139,92,246,0.15); color:var(--accent-purple); }
.dlm-ftype-audio .dlm-item-icon { background:rgba(236,72,153,0.15); color:var(--accent-pink); }
.dlm-ftype-archive .dlm-item-icon { background:rgba(245,158,11,0.15); color:var(--accent-orange); }
.dlm-ftype-image .dlm-item-icon { background:rgba(6,182,212,0.12); color:var(--accent-cyan); }
.dlm-ftype-document .dlm-item-icon { background:rgba(59,130,246,0.12); color:var(--accent); }
.dlm-ftype-code .dlm-item-icon { background:rgba(34,197,94,0.12); color:var(--success); }
.dlm-ftype-torrent .dlm-item-icon { background:rgba(139,92,246,0.15); color:#a78bfa; }

/* Text & labels */
.dl-label { font-size:var(--fs-sm); }
.dl-label-xs { font-size:var(--fs-sm); }
.dl-subsection-title { margin:0 0 var(--space-sm); font-size:var(--fs-sm); color:var(--text-primary); }
.dl-hint-text { font-size:var(--fs-sm); color:var(--text-muted); margin-bottom:var(--space-lg); }
.dl-path-text { font-size:var(--fs-sm); color:var(--text-muted); word-break:break-all; }
.dl-files-info { font-size:var(--fs-sm); color:var(--text-muted); margin-bottom:var(--space-sm); }

/* Form rows */
.dl-form-row-mb { margin-bottom:var(--space-md); }
.dl-form-row-mb-sm { margin-bottom:var(--space-sm); }
.dl-form-row-mb0 { margin-bottom:0; }
.dl-form-row-mb10 { margin-bottom:var(--space-sm); }

/* Checkbox rows */
.dl-checkbox-row { font-size:var(--fs-sm); display:flex; align-items:center; gap:var(--space-sm); margin-bottom:var(--space-sm); }
.dl-checkbox-row-lg { font-size:var(--fs-sm); display:flex; align-items:center; gap:var(--space-sm); margin-bottom:var(--space-sm); }

/* URL preview */
.dl-url-preview { margin-top:var(--space-md); font-size:var(--fs-sm); color:var(--text-muted); max-height:100px; overflow-y:auto; word-break:break-all; }
.dl-url-preview-item { padding:2px 0; }

/* Package */
.dl-caret { margin-right:var(--space-sm); transition:transform 0.2s; transform:rotate(-90deg); }
.dl-pkg-meta { font-size:var(--fs-xs); color:var(--text-muted); margin-left:var(--space-sm); }
.dl-pkg-status { font-size:var(--fs-sm); margin-top:2px; }
.dl-pkg-tag { color:var(--text-muted); font-size:var(--fs-xs); margin-left:var(--space-sm); }
.dl-pkg-tag-ml4 { color:var(--text-muted); font-size:var(--fs-xs); margin-left:var(--space-xs); }
.dl-pkg-error { color:var(--danger); font-size:var(--fs-xs); margin-left:var(--space-sm); }
.dl-progress-mt { margin-top:var(--space-xs); }

/* Status icons */
.dl-si-pending { color:var(--accent-orange); }
.dl-si-resolving { color:#a78bfa; }
.dl-si-torrent { color:var(--accent-purple); }
.dl-si-downloading { color:var(--accent); }
.dl-si-completed { color:var(--success); }
.dl-si-failed { color:var(--danger); }
.dl-si-cancelled { color:var(--text-muted); }

/* Stats bar */
.dl-stat-active { color:var(--accent); }
.dl-stat-pending { color:var(--accent-orange); }
.dl-stat-completed { color:var(--success); }
.dl-stat-speed { color:var(--text-muted); }

/* Error box */
.dl-error-box { margin-top:var(--space-sm); padding:var(--space-sm); background:rgba(239,68,68,0.1); border-radius:var(--r-sm); font-size:var(--fs-sm); color:var(--danger); }

/* Button variants */
.dl-btn-violet { background:var(--accent-purple); }
.dl-btn-sm-text { font-size:var(--fs-sm); }

/* Category badge on download item */
.dlm-cat-badge { font-size:10px; padding:2px 7px; margin-right:var(--space-xs); border:1px solid var(--border); border-radius:10px; background:var(--overlay-3); color:var(--text-secondary); font-weight:500; }

/* Category filter select */
.dlm-cat-filter-select { margin-left:var(--space-xs); width:120px; }

/* Date range inputs */
.dlm-date-input { width:130px; }
.dlm-date-separator { color:var(--text-secondary); font-size:var(--fs-xs); }

/* ═══ NASLink App ═══ */

/* Loading / spinner states */
.nl-loading { text-align:center; padding:40px; color:var(--text-muted); }
.nl-loading-sm { text-align:center; padding:30px; color:var(--text-muted); }
.nl-loading-xs { text-align:center; padding:var(--space-xl); }

/* Panels */
.nl-panel { padding:var(--space-lg); background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--r-md); }
.nl-panel-accent { margin-top:var(--space-lg); background:var(--bg-secondary); border:1px solid var(--accent); border-radius:var(--r-md); padding:var(--space-xl); }
.nl-panel-form { background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--r-md); padding:var(--space-xl); }

/* Status messages */
.nl-status-msg { padding:var(--space-md); color:var(--text-muted); }

/* Color utilities */
.nl-text-muted { color:var(--text-muted); }
.nl-success { color:var(--success); }
.nl-error { color:var(--danger); }

/* Section titles */
.nl-section-title { font-size:15px; font-weight:600; margin:0 0 var(--space-md); display:flex; align-items:center; gap:var(--space-sm); }
.nl-section-title-sm { font-size:var(--fs-base); font-weight:600; margin:0 0 10px; display:flex; align-items:center; gap:var(--space-sm); }
.nl-form-title { margin:0 0 var(--space-lg); font-size:var(--fs-base); font-weight:600; }
.nl-discover-title { margin:0 0 var(--space-md); font-size:13px; font-weight:600; }

/* Section spacing */
.nl-section-mt { margin-top:var(--space-2xl); }
.nl-section-mt-sm { margin-top:var(--space-xl); }

/* Icon utilities */
.nl-icon-accent { color:var(--accent); }
.nl-icon-mr { margin-right:var(--space-sm); color:var(--accent); }
.nl-icon-mr-xs { margin-right:var(--space-xs); }
.nl-icon-muted { color:var(--text-muted); }
.nl-icon-paused { margin-right:6px; color:var(--warning); }
.nl-icon-spin-mr { margin-right:6px; }
.nl-icon-success-mr { color:var(--success); margin-right:6px; }
.nl-icon-error-mr { color:var(--danger); margin-right:6px; }
.nl-key-icon { color:var(--success); font-size:10px; }
.nl-lock-icon { color:var(--text-muted); font-size:10px; }

/* Flex layouts */
.nl-row { display:flex; gap:var(--space-sm); }
.nl-form-actions { display:flex; gap:var(--space-sm); margin-top:14px; align-items:center; }
.nl-tf-actions-row { margin-top:var(--space-sm); display:flex; gap:6px; }
.nl-flex-1 { flex:1; }
.nl-shrink-0 { flex-shrink:0; }

/* Result / message areas */
.nl-result-msg { margin-top:10px; font-size:var(--fs-sm); }

/* Sub-info text */
.nl-sub-info { font-size:var(--fs-xs); color:var(--text-muted); margin-top:2px; }
.nl-hint { font-size:var(--fs-xs); color:var(--text-muted); margin-top:var(--space-xs); }
.nl-muted-sm { font-size:var(--fs-xs); color:var(--text-muted); }
.nl-info-footer { margin-top:var(--space-xl); font-size:var(--fs-sm); color:var(--text-muted); }

/* Discovery */
.nl-discover-row { display:flex; align-items:center; gap:var(--space-md); padding:var(--space-sm) 0; border-bottom:1px solid var(--border); }
.nl-discover-name { font-weight:600; font-size:13px; }

/* Resumed badge */
.nl-badge-resumed { font-size:10px; padding:2px var(--space-sm); border-radius:10px; background:rgba(249,115,22,.12); color:#f97316; font-weight:600; margin-left:var(--space-sm); }

/* Transfer server label */
.nl-tf-srv-label { font-size:var(--fs-sm); color:var(--text-secondary); margin:var(--space-xs) 0; }
.nl-tf-arrow { font-size:10px; margin-right:6px; color:var(--accent); }

/* Snapshot icon variants */
.nl-snap-icon-received { background:rgba(249,115,22,.1); color:#f97316; }
.nl-snap-icon-local { background:rgba(6,182,212,.1); color:#06b6d4; }
.nl-snap-icon-remote { background:rgba(139,92,246,.1); color:#8b5cf6; }
.nl-snap-list-mb { margin-bottom:var(--space-xl); }

/* Heading color variants */
.nl-heading-received { color:#f97316; }
.nl-heading-remote { color:#8b5cf6; }

/* Modal variants */
.nl-modal-sm { max-width:400px; }
.nl-modal-picker { max-width:560px; max-height:85vh; display:flex; flex-direction:column; }

/* File picker */
.nl-picker-bar { padding:var(--space-sm) var(--space-lg); border-bottom:1px solid var(--border); display:flex; align-items:center; gap:6px; flex-shrink:0; }
.nl-picker-input { flex:1; padding:5px 10px; border:1px solid var(--border); border-radius:var(--r-sm); background:var(--bg-primary); color:var(--text-primary); font-size:var(--fs-sm); font-family:monospace; }
.nl-picker-list { flex:1; overflow-y:auto; padding:var(--space-sm) var(--space-lg); min-height:200px; }
.nl-picker-selected { padding:6px var(--space-lg); border-top:1px solid var(--border); font-size:var(--fs-xs); color:var(--text-muted); flex-shrink:0; max-height:60px; overflow-y:auto; }
.nlp-item { display:flex; align-items:center; gap:var(--space-sm); padding:5px var(--space-xs); border-radius:var(--r-sm); cursor:pointer; transition:background .1s; }
.nlp-cb { flex-shrink:0; }
.nl-file-icon { font-size:13px; flex-shrink:0; width:18px; text-align:center; }
.nlp-name { flex:1; font-size:13px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.nlp-enter { color:var(--text-muted); font-size:10px; opacity:.5; flex-shrink:0; padding:var(--space-xs); }
.nlp-file-size { font-size:var(--fs-xs); color:var(--text-muted); flex-shrink:0; }

/* ═══ Storage App ═══ */
.sto-center-lg { text-align:center; padding:40px; }
.sto-center-md { text-align:center; padding:30px; }
.sto-center-sm { text-align:center; padding:var(--space-xl); }
.sto-spinner { font-size:24px; color:var(--accent); }
.sto-load-text { margin-top:var(--space-sm); color:var(--text-muted); }
.sto-mt-sm { margin-top:var(--space-sm); }
.sto-mt-md { margin-top:var(--space-md); }
.sto-ml-sm { margin-left:var(--space-sm); }
.sto-mr-xs { margin-right:6px; }
.sto-modal-lg { max-width:520px; }
.sto-modal-md { max-width:500px; }
.sto-close-btn { padding:var(--space-xs) var(--space-sm); font-size:var(--fs-md); border:none; background:transparent; color:var(--text-muted); cursor:pointer; }
.sto-hdr-icon-orange { margin-right:var(--space-sm); color:#f97316; }
.sto-hdr-icon-green { margin-right:var(--space-sm); color:var(--success); }
.sto-smart-scroll { max-height:400px; overflow-y:auto; }
.sto-info-msg { text-align:center; padding:var(--space-xl); color:var(--text-muted); }
.sto-icon-lg { font-size:24px; }
.sto-error-msg { text-align:center; padding:var(--space-xl); color:var(--danger); }
.sto-smart-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-md); margin-bottom:var(--space-lg); }
.sto-smart-card { padding:14px; border-radius:var(--r-sm); text-align:center; }
.sto-stat-label { font-size:10px; color:var(--text-muted); margin-bottom:var(--space-xs); }
.sto-stat-value { font-size:18px; font-weight:700; }
.sto-smart-table { width:100%; font-size:13px; border-collapse:collapse; }
.sto-tr-border { border-bottom:1px solid var(--border); }
.sto-td-label { padding:6px 0; color:var(--text-muted); }
.sto-td-value { padding:6px 0; text-align:right; font-weight:500; }
.sto-td-mono { padding:6px 0; text-align:right; font-family:monospace; font-size:var(--fs-sm); }
.sto-td-right { padding:6px 0; text-align:right; }
.sto-td-right-bold { padding:6px 0; text-align:right; font-weight:600; }
.sto-alert-danger { margin-top:var(--space-md); padding:var(--space-sm) var(--space-md); background:rgba(239,68,68,.08); border-radius:var(--r-sm); font-size:var(--fs-sm); color:var(--danger); }
.sto-group-icon { width:var(--space-lg); text-align:center; }
.sto-bold { font-weight:600; }
.sto-subtitle { font-size:var(--fs-xs); color:var(--text-muted); }
.sto-optional { color:var(--text-muted); font-weight:400; }
.sto-icon-accent { color:var(--accent); }
.sto-action-icon { margin-right:6px; color:var(--accent); }
.sto-action-sub { color:var(--text-muted); font-weight:400; font-size:var(--fs-sm); }
.sto-ka-on { font-size:10px; opacity:.7; }
.sto-badge-sm { font-size:9px; }
.sto-badge-keepalive { background:rgba(139,92,246,.15); color:#a78bfa; }
.sto-drive-icon-orange { font-size:var(--space-xl); color:#f97316; }
.sto-drive-icon-purple { font-size:var(--space-xl); color:#a855f7; }
.sto-drive-icon-cyan { font-size:var(--space-xl); color:#06b6d4; }
.sto-os-linux { color:#f59e0b; }
.sto-os-windows { color:#3b82f6; }
.sto-os-mac { color:#a78bfa; }
.sto-progress-icon-orange { font-size:24px; color:#f97316; }
.sto-progress-icon-purple { font-size:24px; color:#a855f7; }
.sto-progress-icon-cyan { font-size:24px; color:#06b6d4; }
.sto-log-icon { width:14px; text-align:center; }
.sto-result-ok-icon { font-size:28px; color:var(--success); }
.sto-result-ok-text { font-weight:600; color:var(--success); }
.sto-result-err-icon { font-size:28px; color:var(--danger); }
.sto-result-err-text { font-weight:600; color:var(--danger); }
.sto-result-sub { font-size:var(--fs-sm); color:var(--text-muted); }
.sto-drive-info-merge { border-color:rgba(168,85,247,.2); background:rgba(168,85,247,.06); }
.sto-drive-info-split { border-color:rgba(6,182,212,.2); background:rgba(6,182,212,.06); }
.sto-merge-parts { font-size:var(--fs-xs); margin-top:var(--space-xs); color:#f97316; }
.sto-sys-info-danger { background:rgba(239,68,68,.06); border:1px solid rgba(239,68,68,.15); }
.sto-text-danger { color:var(--danger); }
.sto-split-footer { display:flex; justify-content:space-between; align-items:center; margin-top:var(--space-sm); }
.sto-free-label { font-size:var(--fs-sm); color:var(--text-muted); }

/* ═══ Surveillance App ═══ */
.surv-install-center { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; gap:var(--space-xl); padding:40px; }
.surv-install-icon { font-size:64px; color:#dc2626; opacity:0.3; }
.surv-install-title { color:var(--text-primary); margin:0; }
.surv-install-desc { color:var(--text-muted); text-align:center; max-width:440px; }
.surv-deps-row { display:flex; gap:var(--space-sm); flex-wrap:wrap; justify-content:center; }
.surv-install-btn { margin-top:var(--space-md); padding:10px 32px; font-size:15px; }
.surv-install-progress-wrap { width:100%; max-width:400px; text-align:center; }
.surv-install-msg { color:var(--text-muted); font-size:13px; margin-top:var(--space-sm); }
.surv-modal-narrow { max-width:520px; }
.surv-modal-icon { margin-right:var(--space-sm); color:var(--accent); }
.surv-modal-body-scroll { max-height:60vh; overflow-y:auto; }
.surv-label-mt { margin-top:10px; }
.surv-section-divider { margin-top:14px; padding-top:14px; border-top:1px solid var(--border); }
.surv-label-mb { margin-bottom:6px; }
.surv-onvif-grid-hp { display:grid; grid-template-columns:1fr 80px; gap:var(--space-sm); margin-top:var(--space-sm); }
.surv-onvif-grid-2col { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-sm); margin-top:var(--space-sm); }
.surv-field-note { margin-top:var(--space-sm); font-size:var(--fs-sm); }
.surv-checkbox-row { margin-top:14px; display:flex; gap:var(--space-lg); }
.surv-checkbox-label { display:flex; align-items:center; gap:6px; font-size:13px; cursor:pointer; }
.surv-section-divider-sm { margin-top:var(--space-md); padding-top:var(--space-md); border-top:1px solid var(--border); }
.surv-label-mb-sm { margin-bottom:var(--space-sm); }
.surv-text-danger { color:var(--danger); }
.surv-onvif-stream-item { cursor:pointer; padding:var(--space-xs) 6px; border-radius:4px; margin:2px 0; background:var(--bg-tertiary); }
.surv-code-muted { font-size:var(--fs-xs); color:var(--text-muted); }
.surv-text-muted { color:var(--text-muted); }
.surv-loading-center { padding:var(--space-xl); text-align:center; }
.surv-discovery-pad { padding:var(--space-md); }
.surv-discovery-heading { margin:0 0 10px; color:var(--text-primary); }
.surv-text-sm-muted { font-size:var(--fs-sm); color:var(--text-muted); }
.surv-text-xs { font-size:var(--fs-xs); }
.surv-empty-msg { padding:var(--space-xl); text-align:center; color:var(--text-muted); }
.surv-error-msg { padding:var(--space-xl); color:var(--danger); }
.surv-toolbar-label { font-size:13px; color:var(--text-muted); }
.surv-text-accent { color:var(--accent); }
.surv-skip-label { font-size:10px; }
.surv-settings-title { margin:0 0 18px; color:var(--text-primary); }
.surv-rec-dot-icon { color:#dc2626; font-size:10px; }
.surv-flex-gap-sm { display:flex; gap:var(--space-sm); }
.surv-event-info { font-size:var(--fs-sm); color:var(--text-muted); margin:6px 0 10px; }
.surv-text-warning { color:var(--warning); }
.surv-flex-center { display:flex; align-items:center; gap:var(--space-sm); }
.surv-sens-value { color:var(--text-primary); font-weight:600; font-size:13px; min-width:30px; }
.surv-input-flex { flex:1; }
.surv-mt-lg { margin-top:var(--space-lg); }
.surv-text-purple { color:#7c3aed; }
.surv-info-note { font-size:var(--fs-sm); color:var(--text-muted); margin:var(--space-sm) 0 0; }
.surv-mt-xl { margin-top:var(--space-xl); }
.surv-mt-2xl { margin-top:var(--space-2xl); }
.surv-spinner-icon { font-size:24px; color:var(--accent); }
.surv-loading-msg { margin-top:10px; color:var(--text-muted); }
.surv-diag-url { margin-bottom:var(--space-md); font-size:var(--fs-sm); color:var(--text-muted); word-break:break-all; }
.surv-diag-ok { color:#22c55e; }
.surv-diag-check { margin-bottom:var(--space-sm); padding:var(--space-sm); background:var(--card-bg,rgba(0,0,0,0.1)); border-radius:var(--r-sm); }
.surv-diag-msg { margin-top:var(--space-xs); font-size:13px; color:var(--text-secondary,#aaa); }
.surv-diag-suggestion { margin-top:6px; font-size:var(--fs-sm); padding:6px; background:rgba(59,130,246,0.15); border-radius:4px; }
.surv-text-amber { color:#f59e0b; }
.surv-diag-copy-btn { font-size:var(--fs-xs); padding:2px var(--space-sm); margin-left:6px; }
.surv-diag-info { margin-top:var(--space-xs); font-size:var(--fs-sm); color:#22c55e; }
.surv-diag-summary { margin-top:var(--space-md); padding:10px; text-align:center; border-radius:var(--r-sm); font-weight:600; }

/* ═══ Domains App ═══ */

/* Icon colors */
.dom-icon-primary { color:#059669; }
.dom-icon-blue { color:#3b82f6; }

/* Badges */
.dom-badge { color:#fff; padding:2px var(--space-sm); border-radius:4px; font-size:10px; font-weight:600; }
.dom-badge-ssl { background:#059669; margin-left:6px; }
.dom-badge-ws { background:#7c3aed; margin-left:var(--space-xs); }
.dom-badge-active { background:#059669; margin-left:var(--space-sm); }
.dom-badge-warn { background:#d97706; margin-left:var(--space-sm); }
.dom-badge-muted { background:#6b7280; margin-left:var(--space-sm); }
.dom-badge-free { display:inline-block; font-size:9px; padding:1px 6px; border-radius:var(--space-sm); background:#059669; color:#fff; margin-top:6px; }

/* Domain card parts */
.dom-card-body { flex:1; min-width:0; }
.dom-card-title { font-size:var(--fs-base); font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.dom-card-sub { font-size:var(--fs-xs); color:var(--text-muted); margin-top:2px; }
.dom-card-actions { display:flex; gap:var(--space-xs); flex-shrink:0; }
.dom-status-icon { margin-right:var(--space-xs); font-size:var(--fs-sm); }

/* Certificate card */
.dom-cert-card { flex-direction:column; align-items:stretch; gap:var(--space-sm); }
.dom-cert-header { display:flex; align-items:center; gap:10px; justify-content:space-between; }
.dom-cert-info { display:flex; align-items:center; gap:var(--space-sm); }
.dom-cert-domain { font-size:var(--fs-base); font-weight:700; }
.dom-shield-icon { font-size:18px; }
.dom-btn-group { display:flex; gap:var(--space-xs); }

/* Form helpers */
.dom-target-wrap { display:flex; gap:6px; flex:1; align-items:center; }
.dom-cb-row { gap:var(--space-xl); }
.dom-cb-label { width:auto; }
.dom-cb-gap { margin-right:var(--space-xs); }
.dom-textarea-code { flex:1; padding:var(--space-sm) var(--space-md); border:1px solid var(--border,#334155); border-radius:var(--space-sm); background:var(--bg-input,#0f172a); color:var(--text); font-size:var(--fs-sm); font-family:monospace; resize:vertical; }
.dom-input-compact { padding:6px 10px; border:1px solid var(--border); border-radius:var(--r-sm); background:var(--bg-input); color:var(--text); font-size:13px; text-align:center; }

/* Sections & dividers */
.dom-section-sep { margin-top:14px; border-top:1px solid var(--border,#334155); padding-top:14px; }
.dom-section-title { font-size:13px; font-weight:600; margin-bottom:10px; }

/* Pre / code blocks */
.dom-pre-output { background:var(--bg-input,#0f172a); border:1px solid var(--border); border-radius:var(--space-sm); padding:var(--space-md); font-size:var(--fs-xs); color:#94a3b8; overflow-x:auto; margin-top:10px; }
.dom-pre-block { background:var(--bg-input); border:1px solid var(--border); border-radius:var(--space-sm); padding:var(--space-md); font-size:var(--fs-xs); color:#94a3b8; overflow-x:auto; white-space:pre-wrap; }

/* DDNS settings */
.dom-settings-row { display:flex; align-items:center; gap:var(--space-md); margin-bottom:14px; }
.dom-settings-row-sm { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.dom-label-text { font-size:13px; font-weight:500; }
.dom-fz-13 { font-size:13px; }
.dom-empty-text { color:var(--text-muted); font-size:13px; padding:10px; }
.dom-expiry-box { margin-top:10px; padding:10px 14px; background:var(--bg-input); border:1px solid var(--border); border-radius:var(--space-sm); font-size:13px; }

/* Add provider cards */
.dom-add-title { font-weight:600; font-size:13px; margin-bottom:var(--space-xs); }
.dom-add-desc { font-size:var(--fs-xs); color:var(--text-muted); line-height:1.4; }

/* History table */
.dom-truncate { max-width:200px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* Service list */
.dom-svc-wrap { display:flex; flex-wrap:wrap; gap:6px; }

/* Utility */
.dom-nowrap { white-space:nowrap; }
.dom-loading { text-align:center; padding:var(--space-lg); }
.dom-m-0 { margin:0; }
.dom-mt-0 { margin-top:0; }
.dom-mt-xs { margin-top:6px; }
.dom-mt-sm { margin-top:var(--space-sm); }
.dom-mb-md { margin-bottom:var(--space-md); }
.dom-mr-xs { margin-right:6px; }
.dom-mr-md { margin-right:var(--space-md); }
.dom-hint-flush { margin-left:0; }
.dom-hint-flush-mb { margin-left:0; margin-bottom:10px; }
.dom-row-gap { gap:10px; }
.dom-text-sm { font-size:var(--fs-sm); }
.dom-text-xs { font-size:var(--fs-xs); }
.dom-lh-relaxed { line-height:1.5; }

/* ═══ Resources App ═══ */
.res-conn-dot { font-size: 8px; }
.res-conn-online { color: #2dd4a8; }
.res-gpu-nodetect { font-size: .7em; opacity: .5; }
.res-gpu-hint { opacity: .5; font-size: .8em; }
.res-net-dl-icon { color: #2dd4a8; }
.res-net-ul-icon { color: #3b82f6; }
.res-mt-md { margin-top: var(--space-md); }
.res-mt-sm { margin-top: var(--space-sm); }
.res-mb-md { margin-bottom: var(--space-md); }
.res-text-muted { color: var(--text-muted); }
.res-empty-icon { font-size: 2.5rem; opacity: .4; margin-bottom: var(--space-md); }
.res-empty-title { font-size: 1.1rem; margin-bottom: var(--space-sm); }
.res-empty-desc { font-size: .85rem; opacity: .6; max-width: 480px; line-height: 1.6; margin: 0 auto; }
.res-empty-detect { opacity: .5; }
.res-ram-center { text-align: center; font-size: 1.5em; margin: var(--space-sm) 0; }
.res-disk-row { display: flex; align-items: center; gap: 10px; padding: var(--r-sm) 0; border-bottom: 1px solid rgba(255,255,255,0.04); }
.res-disk-row-icon { width: var(--space-lg); text-align: center; font-size: var(--fs-sm); }
.res-disk-row-name { font-size: var(--fs-sm); font-weight: 600; min-width: 80px; }
.res-disk-row-bar { flex: 1; display: flex; align-items: center; gap: var(--space-sm); }
.res-disk-row-pct { font-size: var(--fs-xs); font-weight: 700; min-width: 36px; text-align: right; }
.res-disk-row-size { font-size: 10px; color: var(--text-muted); white-space: nowrap; }
.res-disk-model { color: #94a3b8; font-style: italic; }
.res-gpu-card-body { padding: var(--space-md) var(--space-lg); }
.res-flex-row-mb { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.res-label { font-size: .85rem; opacity: .7; }
.res-vendor-name { font-weight: 600; text-transform: uppercase; }
.res-mono-sm { font-size: .85rem; font-family: monospace; }
.res-gpu-status-ok { margin-top: var(--space-md); display: flex; align-items: center; gap: var(--space-sm); padding: 10px var(--space-lg); background: rgba(34,197,94,.12); border-radius: var(--space-sm); border: 1px solid rgba(34,197,94,.3); }
.res-gpu-status-ok-icon { color: #22c55e; font-size: 1.1rem; }
.res-gpu-status-ok-text { font-size: .9rem; font-weight: 600; color: #22c55e; }
.res-gpu-status-warn { margin-top: var(--space-md); display: flex; align-items: center; gap: var(--space-sm); padding: 10px var(--space-lg); background: rgba(245,158,11,.12); border-radius: var(--space-sm); border: 1px solid rgba(245,158,11,.35); }
.res-gpu-status-warn-icon { color: #f59e0b; font-size: 1.1rem; }
.res-gpu-status-warn-text { font-size: .9rem; font-weight: 600; color: #f59e0b; }
.res-reboot-area { margin-top: 10px; display: flex; gap: var(--space-sm); align-items: center; }
.res-reboot-btn { background: var(--danger); color: #fff; border: none; padding: var(--space-sm) var(--space-xl); border-radius: var(--r-sm); cursor: pointer; font-size: .85rem; font-weight: 600; display: flex; align-items: center; gap: var(--r-sm); }
.res-gpu-install-btn-base { color: #fff; border: none; padding: 10px var(--space-2xl); border-radius: var(--space-sm); cursor: pointer; font-size: .95rem; font-weight: 600; display: flex; align-items: center; gap: var(--space-sm); transition: opacity .2s; }
.res-no-install { opacity: .5; font-size: .85rem; }
.res-install-wrap { margin-top: var(--space-xs); }
.res-install-status-row { display: flex; align-items: center; gap: var(--space-sm); margin-bottom: var(--r-sm); }
.res-install-spinner { color: #f59e0b; }
.res-install-status { font-size: .85rem; }
.res-install-bar-bg { background: rgba(255,255,255,.08); border-radius: var(--r-sm); height: 22px; overflow: hidden; position: relative; }
.res-install-bar-fill { height: 100%; width: 0%; background: linear-gradient(90deg,#f59e0b,#22c55e); border-radius: var(--r-sm); transition: width .4s ease; }
.res-install-bar-pct { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: .75rem; font-weight: 700; }
.res-install-detail { margin-top: var(--r-sm); font-size: .75rem; opacity: .5; font-family: monospace; max-height: 60px; overflow-y: auto; word-break: break-all; }
.res-status-success { color: #22c55e; }
.res-status-error { color: var(--danger); }
.res-proc-card { margin-top: var(--space-sm); max-height: 450px; overflow-y: auto; }
.res-usb-badge { font-size: 10px; padding: 2px var(--r-sm); background: rgba(167,139,250,.12); color: #a78bfa; border-radius: var(--space-xs); font-weight: 600; }
.res-usb-hdr { display: flex; align-items: center; gap: var(--space-sm); }
.res-usb-info { gap: var(--space-md); flex-wrap: wrap; }
.res-usb-icon { color: #a78bfa; }
.res-icon-muted { opacity: .5; margin-right: var(--space-xs); }
.res-proc-search { max-width: 300px; }

/* System info section */
.res-sys-info { display: flex; flex-direction: column; gap: 2px; }
.res-sys-row { display: flex; align-items: center; padding: 6px 8px; border-radius: 6px; }
.res-sys-row:nth-child(odd) { background: rgba(255,255,255,.03); }
.res-sys-icon { width: 20px; color: var(--accent); opacity: .7; margin-right: 10px; text-align: center; flex-shrink: 0; }
.res-sys-label { font-size: 12px; color: var(--text-secondary); min-width: 130px; flex-shrink: 0; }
.res-sys-val { font-size: 13px; color: var(--text-primary); font-weight: 500; }

/* Hardware detail rows (CPU section) */
.res-hw-details { display: flex; flex-direction: column; gap: 2px; }
.res-hw-row { display: flex; align-items: center; padding: 6px 8px; border-radius: 6px; }
.res-hw-row:nth-child(odd) { background: rgba(255,255,255,.03); }
.res-hw-label { font-size: 12px; color: var(--text-secondary); min-width: 130px; flex-shrink: 0; }
.res-hw-val { font-size: 13px; color: var(--text-primary); }
.res-hw-flags { display: flex; flex-wrap: wrap; gap: 4px; }
.res-hw-flag { display: inline-block; font-size: 10px; padding: 2px 8px; background: rgba(59,130,246,.12); color: #60a5fa; border-radius: 4px; font-weight: 600; font-family: monospace; letter-spacing: .5px; }

/* System summary bar (overview top) */
.res-sys-summary { display: flex; align-items: center; gap: 16px; padding: 8px 14px; margin-bottom: 12px; background: rgba(59,130,246,.06); border: 1px solid rgba(59,130,246,.12); border-radius: 8px; font-size: 13px; color: var(--text-secondary); }
.res-sys-summary i { color: var(--accent); opacity: .7; margin-right: 6px; }


/* ═══════════════════════════════════════════════
   Tickets — Kanban Board / Project Management
   ═══════════════════════════════════════════════ */

/* ─── Main Container ─── */
.tk-app {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-base);
  overflow: hidden;
}

/* ─── Toolbar ─── */
.tk-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.tk-toolbar-title { font-weight: 600; flex: 1; font-size: 15px; }
.tk-btn {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 6px 14px;
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast);
}
.tk-btn:hover { background: var(--bg-hover); }
.tk-btn-small, .tk-btn-sm {
  padding: 4px 10px;
  font-size: 12px;
}
.tk-btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.tk-btn-primary:hover { filter: brightness(1.1); }
.tk-btn-danger {
  background: var(--danger);
  color: #fff;
  border-color: var(--danger);
}
.tk-btn-danger:hover { filter: brightness(1.1); }
.tk-btn-back { padding: 6px 10px; margin-right: var(--space-xs); }
.tk-board-title {
  font-weight: 600;
  font-size: 15px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tk-search {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 6px 12px;
  width: 200px;
  font-size: 13px;
  color: var(--text);
  transition: border-color var(--transition-fast);
}
.tk-search:focus { border-color: var(--accent); outline: none; }

/* ─── Project List View ─── */
.tk-projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  padding: 20px;
  overflow-y: auto;
  flex: 1;
}
.tk-project-card {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  cursor: pointer;
  transition: box-shadow var(--transition-fast), transform var(--transition-fast), border-color var(--transition-fast);
  position: relative;
  overflow: hidden;
}
.tk-project-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
  border-color: var(--accent);
}
.tk-project-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.tk-project-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.tk-project-color {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 4px;
}
.tk-project-name { font-weight: 600; font-size: 15px; margin-bottom: 8px; padding-left: 8px; }
.tk-project-desc {
  color: var(--text-secondary);
  font-size: 12px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  padding-left: 8px;
}
.tk-project-stats {
  display: flex;
  gap: var(--space-md);
  font-size: 12px;
  margin-top: 12px;
  color: var(--text-muted);
  padding-left: 8px;
}
.tk-project-members { display: flex; gap: 4px; margin-top: 8px; padding-left: 8px; }
.tk-project-avatar {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-size: 11px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600;
}
.tk-project-actions { display: flex; gap: 4px; margin-top: 12px; padding-left: 8px; }
.tk-project-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  font-size: 12px;
  color: var(--text-muted);
}

/* ─── Kanban Board ─── */
.tk-board {
  display: flex;
  flex: 1;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 12px;
  gap: 12px;
}
.tk-column {
  min-width: 260px;
  width: 260px;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  background: var(--bg-deep);
  border-radius: var(--r-lg);
  flex-shrink: 0;
}
.tk-column-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  font-weight: 600;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
}
.tk-col-select-all {
  cursor: pointer;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  accent-color: var(--accent, #3b82f6);
}
.tk-column-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}
.tk-column-count {
  background: var(--overlay-3);
  border-radius: var(--r-sm);
  font-size: 11px;
  padding: 1px 8px;
  color: var(--text-muted);
  font-weight: 500;
}
.tk-column-body {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  padding: 8px;
  gap: 8px;
}
.tk-column-dragover {
  border: 2px dashed var(--accent);
  background: color-mix(in srgb, var(--accent) 6%, transparent);
  border-radius: var(--r-lg);
}

/* ─── Ticket Cards ─── */
.tk-card {
  position: relative;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 10px 12px;
  cursor: grab;
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}
.tk-card:hover {
  box-shadow: var(--shadow-sm);
  border-color: var(--accent);
}
.tk-card:focus, .tk-card-child:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--accent);
  border-color: var(--accent);
  z-index: 10;
}
.tk-column:focus {
  outline: none;
  box-shadow: inset 0 0 0 2px var(--accent);
  border-radius: var(--r-lg);
}
.tk-card-dragging {
  opacity: 0.4;
  transform: rotate(2deg);
}
.tk-card-header {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  margin-bottom: 2px;
}
.tk-card-title {
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 6px;
  word-break: break-word;
  line-height: 1.4;
}
.tk-card-meta {
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--text-muted);
}
.tk-priority-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.tk-complexity-badge {
  font-size: 9px;
  font-weight: 700;
  color: #fff;
  padding: 1px 5px;
  border-radius: 3px;
  flex-shrink: 0;
  margin-left: auto;
  margin-right: 20px;
  line-height: 1.2;
  text-transform: uppercase;
  opacity: 0.85;
}
.tk-card-assignee { color: var(--text-secondary); font-size: 11px; }
.tk-card-labels { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 6px; }
.tk-label {
  display: inline-block;
  padding: 1px 8px;
  border-radius: var(--r-sm);
  font-size: 10px;
  font-weight: 600;
  color: #fff;
  opacity: 0.9;
  line-height: 1.6;
}

/* ─── Filter Bar ─── */
.tk-filter-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.tk-filter-select {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 4px 10px;
  font-size: 12px;
  color: var(--text);
}
.tk-filter-search {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 4px 10px;
  font-size: 12px;
  color: var(--text);
  width: 200px;
}
.tk-filter-search:focus,
.tk-filter-select:focus { border-color: var(--accent); outline: none; }

/* ─── Modals ─── */
.tk-modal-field { margin-bottom: 14px; }
.tk-modal-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 4px;
  color: var(--text-secondary);
}
.tk-modal-input {
  width: 100%;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  color: var(--text);
  font-size: 13px;
  transition: border-color var(--transition-fast);
  box-sizing: border-box;
}
.tk-modal-input:focus { border-color: var(--accent); outline: none; }
.tk-modal-textarea {
  width: 100%;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  color: var(--text);
  font-size: 13px;
  min-height: 100px;
  resize: vertical;
  font-family: inherit;
  box-sizing: border-box;
  transition: border-color var(--transition-fast);
}
.tk-modal-textarea:focus { border-color: var(--accent); outline: none; }
.tk-modal-select {
  width: 100%;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  color: var(--text);
  font-size: 13px;
  box-sizing: border-box;
}
.tk-modal-color-row { display: flex; gap: 8px; flex-wrap: wrap; }
.tk-modal-color-swatch {
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform var(--transition-fast), border-color var(--transition-fast);
}
.tk-modal-color-swatch:hover { transform: scale(1.15); }
.tk-modal-color-swatch.active {
  border-color: #fff;
  box-shadow: 0 0 0 2px var(--accent);
}

/* ─── Ticket Detail View ─── */
.tk-detail { display: flex; gap: 20px; padding: 16px; overflow-y: auto; flex: 1; }
.tk-detail-main { flex: 1; min-width: 0; }
.tk-detail-sidebar { width: 200px; flex-shrink: 0; }
.tk-detail-title { font-size: 18px; font-weight: 600; margin-bottom: 12px; }
.tk-detail-desc {
  font-size: 13px;
  line-height: 1.6;
  white-space: pre-wrap;
  color: var(--text);
}
.tk-detail-field { margin-bottom: 12px; }
.tk-detail-field-label {
  font-size: 11px;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 4px;
  letter-spacing: 0.03em;
  font-weight: 600;
}

/* ─── Comments ─── */
.tk-comments { margin-top: 16px; border-top: 1px solid var(--border); padding-top: 16px; }
.tk-comment {
  margin-bottom: 12px;
  padding: 10px;
  background: var(--bg-deep);
  border-radius: var(--r-md);
}
.tk-comment-header {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.tk-comment-author { font-weight: 600; color: var(--text); }
.tk-comment-body { font-size: 13px; white-space: pre-wrap; line-height: 1.5; }
.tk-comment-date { font-size: 10px; color: var(--text-muted); }
.tk-comment-delete {
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 10px;
  padding: 2px 4px;
  border-radius: 3px;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
}
.tk-comment:hover .tk-comment-delete { opacity: 1; }
.tk-comment-delete:hover { color: #ef4444; }
.tk-comment-text { font-size: 13px; white-space: pre-wrap; line-height: 1.5; }
.tk-comment-input { display: flex; gap: 8px; margin-top: 8px; }
.tk-comment-input .tk-modal-textarea { min-height: 60px; flex: 1; }

/* ─── Copilot Logs ─── */
.tk-copilot-logs-section label { display:block; margin-bottom:8px; font-weight:600; }
.tk-log-tabs { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:8px; }
.tk-log-tab {
  padding: 5px 10px;
  border: 1px solid var(--overlay-2);
  border-radius: var(--r-md);
  background: var(--bg-deep);
  color: var(--text-muted);
  font-size: 11px;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
}
.tk-log-tab:hover { border-color: var(--accent); color: var(--text); }
.tk-log-tab.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.tk-log-size { opacity:0.6; font-size:10px; margin-left:4px; }
.tk-log-tab.active .tk-log-size { opacity:0.8; }
.tk-log-viewer {
  max-height: 70vh;
  min-height: 150px;
  resize: vertical;
  overflow-y: auto;
  background: #0d1117;
  border: 1px solid var(--overlay-2);
  border-radius: var(--r-md);
  padding: 0;
}

@media (max-width: 768px) {
  .tk-log-viewer {
    max-height: 50vh;
  }
}
.tk-log-content {
  margin: 0;
  padding: 12px;
  font-family: 'Cascadia Code', 'Fira Code', 'JetBrains Mono', monospace;
  font-size: 11px;
  line-height: 1.6;
  color: #c9d1d9;
  white-space: pre-wrap;
  word-break: break-word;
}
.tk-log-loading, .tk-log-error {
  padding: 24px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
}
.tk-log-error { color: #f97316; }
.tk-log-live-badge {
  font-size: 11px;
  color: #22c55e;
  font-weight: 600;
  margin-left: 8px;
  animation: tk-pulse 1.5s ease-in-out infinite;
}
@keyframes tk-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* ─── Agent Active Badge on Cards ─── */
.tk-agent-active {
  border-color: rgba(34,197,94,0.5);
  box-shadow: 0 0 8px rgba(34,197,94,0.2);
}
.tk-agent-badge {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 6px;
  padding: 3px 8px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  color: #22c55e;
  background: rgba(34,197,94,0.1);
  animation: tk-pulse 1.5s ease-in-out infinite;
}
.tk-agent-badge i { font-size: 12px; }

/* ─── Agent Status in Detail Modal ─── */
.tk-agent-section label {
  display: block;
  margin-bottom: 8px;
  font-weight: 600;
}
.tk-agent-status-live {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--r-sm);
  background: rgba(34,197,94,0.08);
  font-size: 13px;
  margin-bottom: 8px;
}
.tk-agent-pulse {
  color: #22c55e;
  font-size: 14px;
  animation: tk-pulse 1.5s ease-in-out infinite;
}
.tk-model-history {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: 12px;
  color: var(--text-muted);
}
.tk-model-history-label {
  font-weight: 600;
  color: var(--text-secondary);
}
.tk-model-tag {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  background: var(--overlay-2);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-secondary);
}
.tk-log-model {
  opacity: 0.6;
  font-size: 10px;
  margin-left: 2px;
}

/* ─── Empty States ─── */
.tk-empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--text-muted);
  font-size: 14px;
}
.tk-empty-col {
  text-align: center;
  padding: 20px 12px;
  color: var(--text-muted);
  font-size: 12px;
  opacity: 0.6;
}
.tk-empty i {
  font-size: 48px;
  margin-bottom: 12px;
  opacity: 0.3;
  display: block;
}

/* ─── Utility ─── */
.tk-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  background: var(--overlay-2);
  color: var(--text-muted);
}
.tk-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 12px 0;
}

/* ─── Tickets: Detail extras ─── */
.tk-loading {
  padding: 2rem;
  text-align: center;
  color: var(--text-muted);
}
.tk-comments-list {
  max-height: 300px;
  overflow-y: auto;
}
.tk-comments-section label { display: block; font-weight: 600; margin-bottom: 6px; }
.tk-labels-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 24px;
}
.tk-label-removable {
  cursor: default;
}
.tk-label-removable i {
  cursor: pointer;
  margin-left: 4px;
  opacity: 0.7;
  font-size: 9px;
}
.tk-label-removable i:hover { opacity: 1; }
.tk-ticket-id {
  font-size: 10px;
  font-family: 'SF Mono', 'Fira Code', monospace;
  color: var(--text-muted);
  opacity: 0.7;
  user-select: all;
}
.tk-detail-form { max-width: 100%; }
.tk-detail-meta { font-size: 0.8rem; opacity: 0.6; }


/* ─── Tickets: Form Styles ─── */
.tk-form {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 16px 20px;
}
.tk-form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.tk-form-group {
    display: flex;
    flex-direction: column;
    gap: 5px;
    margin-bottom: 10px;
}
.tk-form label,
.tk-form .tk-label-text {
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin: 0;
    padding: 0;
}
.tk-form label small {
    font-weight: 400;
    text-transform: none;
    letter-spacing: normal;
    opacity: 0.75;
}
.tk-input {
    width: 100%;
    padding: 9px 12px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text);
    background: var(--bg-deep, var(--bg));
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    outline: none;
    box-sizing: border-box;
}
.tk-input:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.12);
}
.tk-input::placeholder {
    color: var(--text-secondary);
    opacity: 0.7;
}
textarea.tk-input {
    resize: vertical;
    min-height: 72px;
    line-height: 1.5;
}
select.tk-input {
    cursor: pointer;
    appearance: auto;
}
.tk-color-picker {
    display: flex;
    align-items: center;
    gap: 10px;
}
.tk-color-picker input[type="color"] {
    width: 40px;
    height: 34px;
    padding: 2px;
    border: 1px solid var(--border);
    border-radius: var(--r-sm);
    background: var(--bg-deep, var(--bg));
    cursor: pointer;
}
.tk-color-picker .tk-color-hex {
    font-size: 12px;
    font-family: 'SF Mono', 'Fira Code', monospace;
    color: var(--text-muted);
}
.tk-form .tk-detail-sidebar-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}

/* ─── Chip Picker ─── */
.tk-chip-picker { display: flex; flex-direction: column; gap: 8px; }
.tk-chips { display: flex; flex-wrap: wrap; gap: 6px; min-height: 28px; }
.tk-chip {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--accent); color: #fff;
  padding: 3px 10px; border-radius: 12px;
  font-size: 12px; font-weight: 500;
}
.tk-chip i { cursor: pointer; opacity: 0.7; font-size: 10px; }
.tk-chip i:hover { opacity: 1; }
.tk-chip-select { font-size: 12px; padding: 4px 8px; }

/* ─── Delete project button ─── */
.tk-delete-project { opacity: 0.5; transition: opacity 0.15s, color 0.15s; }
.tk-delete-project:hover { opacity: 1; color: #ef4444; }

/* ─── Filter group ─── */
.tk-filter-group {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 2px 4px 2px 8px;
}
.tk-filter-group .tk-filter-select {
  border: none; background: transparent;
  padding: 4px 6px; font-size: 12px;
  color: var(--text);
}
.tk-filter-group .tk-filter-select:focus { border: none; box-shadow: none; outline: none; }

/* ─── Search wrap ─── */
.tk-search-wrap {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 2px 8px;
}
.tk-search-wrap .tk-search {
  border: none; background: transparent;
  padding: 4px 6px; outline: none;
  width: 160px; color: var(--text);
}
.tk-search-wrap .tk-search:focus { border: none; box-shadow: none; }
.tk-search-wrap i { font-size: 11px; opacity: 0.4; }

/* ─── Action Buttons (Docker-style) ─── */
.tk-actions { display: flex; gap: 3px; }
.tk-act-btn {
    width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
    border: none; border-radius: var(--r-sm); background: rgba(255,255,255,0.05);
    color: var(--text-muted); cursor: pointer; font-size: 11px; transition: all var(--transition-fast);
}
.tk-act-btn:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }
.tk-act-btn.danger:hover { color: var(--danger); background: rgba(239,68,68,0.15); }

/* ─── Copilot Toggle Switch ─── */
.tk-toggle-row {
    display: flex; align-items: center; gap: 10px;
    cursor: pointer; user-select: none;
    margin: 0; padding: 0; font-weight: normal;
}
.tk-toggle-row input[type="checkbox"] { display: none; }
.tk-toggle-slider {
    position: relative; width: 36px; height: 20px;
    background: var(--border); border-radius: 10px;
    transition: background 0.2s; flex-shrink: 0;
}
.tk-toggle-slider::after {
    content: ''; position: absolute; top: 2px; left: 2px;
    width: 16px; height: 16px; background: #fff; border-radius: 50%;
    transition: transform 0.2s;
}
.tk-toggle-row input:checked + .tk-toggle-slider {
    background: var(--accent);
}
.tk-toggle-row input:checked + .tk-toggle-slider::after {
    transform: translateX(16px);
}
.tk-toggle-label {
    font-size: 13px; font-weight: 500; color: var(--text-primary);
}
.tk-toggle-hint {
    display: block; font-size: 11px; color: var(--text-secondary);
    margin-top: 2px; padding-left: 46px;
}

/* Dashboard toolbar */
.dash-toolbar { display:flex; align-items:center; gap:8px; padding:10px 16px; border-bottom:1px solid var(--border,#1e293b); }
.dash-toolbar-title { font-size:14px; font-weight:600; color:var(--text-secondary,#94a3b8); display:flex; align-items:center; gap:6px; }
.dash-toolbar-title i { font-size:13px; }
.dash-spin i { animation: dash-rotate .6s ease; }
@keyframes dash-rotate { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
\n/* Nested ticket styles: child/epic */\n.tk-card-child { margin-left: 12px; border-left: 3px solid rgba(255,255,255,0.03); padding-left: 8px; opacity: 0.98; }\n.tk-epic-card { background: linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01)); border-left: 4px solid rgba(58,141,255,0.12); }\n


/* ═══ Jira-like Epic / Subtask styles ═══ */

/* Epic colors — rotate through these for distinct epic bands */
.tk-epic-group { margin-bottom: 2px; }

.tk-epic-card {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  border-left: 4px solid var(--epic-color, #6554c0);
  padding: 10px 12px;
  cursor: grab;
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
}
.tk-epic-card:hover {
  box-shadow: var(--shadow-sm);
  border-color: color-mix(in srgb, var(--epic-color, #6554c0) 60%, var(--border));
}
.tk-epic-card .tk-card-header { display: flex; align-items: flex-start; gap: 8px; }

.tk-epic-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--epic-color, #6554c0);
  margin-top: 4px;
}
.tk-epic-badge i { font-size: 9px; }

.tk-epic-progress {
  display: flex; align-items: center; gap: 8px;
  margin-top: 6px;
}
.tk-epic-progress-bar {
  flex: 1; height: 4px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px; overflow: hidden;
}
.tk-epic-progress-fill {
  height: 100%; border-radius: 2px;
  background: var(--epic-color, #6554c0);
  transition: width 0.3s ease;
}
.tk-epic-progress-text {
  font-size: 10px; color: var(--text-muted);
  white-space: nowrap;
}

.tk-epic-toggle {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); font-size: 10px;
  padding: 2px 4px; border-radius: 3px;
  transition: background 0.15s;
}
.tk-epic-toggle:hover { background: rgba(255,255,255,0.06); color: var(--text); }

/* Children container */
.tk-epic-children {
  margin-left: 16px;
  padding-left: 12px;
  border-left: 2px solid color-mix(in srgb, var(--epic-color, #6554c0) 25%, transparent);
  margin-bottom: 4px;
}
.tk-epic-children.collapsed { display: none; }

/* Child cards — slightly smaller, subtask feel */
.tk-card-child {
  position: relative;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 8px 10px;
  cursor: grab;
  transition: box-shadow var(--transition-fast), border-color var(--transition-fast);
  font-size: 12px;
}
.tk-card-child:hover {
  box-shadow: var(--shadow-sm);
  border-color: var(--accent);
}
.tk-card-child + .tk-card-child { margin-top: 4px; }
.tk-card-child .tk-card-title { font-size: 12px; margin-bottom: 4px; }
.tk-card-child .tk-card-header { display: flex; align-items: flex-start; gap: 6px; }

.tk-child-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 9px; color: var(--text-muted);
  margin-top: 2px;
}
.tk-child-badge i { font-size: 8px; }

/* Subtask checkbox-style icon in child cards */
.tk-subtask-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 14px; height: 14px;
  border: 1.5px solid var(--epic-color, #6554c0);
  border-radius: 3px;
  font-size: 8px; color: var(--epic-color, #6554c0);
  flex-shrink: 0; margin-top: 1px;
}
.tk-subtask-icon.done { background: var(--epic-color, #6554c0); color: #fff; }

/* ── Drop indicator for in-column reordering ── */
.tk-drop-indicator {
  height: 3px;
  background: #4c9aff;
  border-radius: 2px;
  margin: 2px 0;
  pointer-events: none;
  box-shadow: 0 0 6px rgba(76,154,255,0.5);
  transition: opacity 0.15s;
}
.tk-column-dragover { background: rgba(76,154,255,0.04) !important; }

/* FM Selection Box (Marquee) */
.fm-selection-box {
    position: absolute;
    border: 1px solid var(--accent);
    background: rgba(139, 92, 246, 0.2); /* Accent color with opacity */
    z-index: 9999;
    pointer-events: none;
}

/* FM Mobile Improvements */
@media (max-width: 768px) {
    #fm-sort-label { display: none; }
    .fm-toolbar-btn { padding: 10px; } /* Larger touch targets */
    
    /* Hide less critical buttons */
    #fm-shortcuts-btn, 
    #fm-upload-folder, 
    #fm-analyze { 
        display: none !important; 
    }
    
    /* Improve breadcrumb scrolling */
    .fm-breadcrumb {
        overflow-x: auto;
        -webkit-mask-image: linear-gradient(to right, black 90%, transparent 100%);
        mask-image: linear-gradient(to right, black 90%, transparent 100%);
    }

    /* Adjust toolbar layout */
    .fm-toolbar {
        gap: 2px;
        padding: 4px;
        overflow-x: auto;
    }

    .fm-view-switcher { display: none; } /* Hide view switcher to save space, default view usually fine */
}

/* ─── Mobile / Responsive Board (Ticket t_3db53b8d5c87) ─── */
@media (max-width: 768px) {
    /* Horizontal Scroll Snap */
    .tk-board {
        scroll-snap-type: x mandatory;
        padding: 0;
        gap: 0;
    }
    
    .tk-column {
        scroll-snap-align: center;
        min-width: 280px;
        max-width: 320px;
        width: 85vw;
        margin: 0 8px;
        height: calc(100% - 16px);
    }
    
    .tk-column:first-child { margin-left: 16px; }
    .tk-column:last-child { margin-right: 16px; }

    /* Compact Toolbar */
    .tk-toolbar {
        padding: 8px;
        gap: 8px;
    }
    .tk-toolbar .tk-btn {
        padding: 6px 10px;
        font-size: 0; /* Hide text */
    }
    .tk-toolbar .tk-btn i {
        font-size: 16px; /* Show icon */
        margin: 0;
    }
    .tk-board-title {
        font-size: 14px;
        flex: 1;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }
    
    /* Filter Bar Toggle */
    .tk-filter-bar {
        display: none;
    }
    .tk-filter-bar.visible {
        display: flex;
        flex-direction: column;
        align-items: stretch;
        padding: 12px;
        background: var(--bg-deep);
        border-bottom: 1px solid var(--border);
        animation: tk-slide-down 0.2s ease-out;
    }
    
    @keyframes tk-slide-down {
        from { opacity: 0; transform: translateY(-10px); }
        to { opacity: 1; transform: translateY(0); }
    }

    .tk-filter-group {
        margin-bottom: 8px;
        width: 100%;
        box-sizing: border-box;
    }
    .tk-search-wrap {
        width: 100%;
        box-sizing: border-box;
    }
    .tk-search-wrap .tk-search {
        width: 100%;
    }
    
    /* Touch Friendly Hitboxes */
    .tk-card, .tk-epic-card {
        padding: 14px;
        user-select: none;
        touch-action: pan-x pan-y;
    }
    
    /* Dragging Visuals */
    .tk-card-dragging-mobile {
        position: fixed !important;
        z-index: 9999 !important;
        opacity: 0.9 !important;
        pointer-events: none !important;
        transform: scale(1.05);
        box-shadow: var(--shadow-md);
        width: 80vw !important;
        left: 0;
        top: 0;
    }
    
    /* Mobile Toolbar Filter Button - Ensure visible */
    #tk-mobile-filter-toggle {
        display: inline-flex !important;
    }
}

/* Ensure mobile toggle is hidden on desktop */
#tk-mobile-filter-toggle {
    display: none;
}

/* ═══ App Store Configuration ═══ */
.as-config-section {
    margin-top: 16px;
    padding: 12px;
    background: var(--overlay-1);
    border: 1px solid var(--border);
    border-radius: var(--r-md);
}
.as-config-title {
    font-size: 0.9rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--text);
    display: flex;
    align-items: center;
    gap: 8px;
}
.as-config-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
    margin-bottom: 12px;
}
.as-config-table th {
    text-align: left;
    color: var(--text-muted);
    font-weight: 500;
    padding: 6px 8px;
    border-bottom: 1px solid var(--border);
}
.as-config-table td {
    padding: 6px 8px;
    border-bottom: 1px solid var(--border);
    vertical-align: middle;
}
.as-config-table tr:last-child td { border-bottom: none; }
.as-config-input {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 4px 8px;
    border-radius: var(--r-sm);
    font-size: 0.85rem;
}
.as-config-input:focus {
    border-color: var(--accent);
    outline: none;
}
.as-config-warning {
    color: #fbbf24;
    font-size: 0.75rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.as-config-error {
    color: var(--danger);
    font-size: 0.75rem;
    margin-top: 4px;
    display: flex;
    align-items: center;
    gap: 4px;
}
.as-svc-header {
    background: var(--overlay-2);
    padding: 6px 10px;
    font-weight: 600;
    font-size: 0.85rem;
    border-radius: var(--r-sm);
    margin-bottom: 8px;
    margin-top: 8px;
}

/* ═══════════════════════════════════════════════════════════
   Notifications — Channels, Triggers, History
   ═══════════════════════════════════════════════════════════ */

.nch-wrap { display: flex; height: 100%; }

.nch-loading {
    display: flex; align-items: center; justify-content: center;
    height: 100%; gap: 10px; color: var(--text-muted);
}

.nch-sidebar {
    width: 150px; min-width: 150px; background: var(--bg-secondary);
    border-right: 1px solid var(--border); overflow-y: auto;
    display: flex; flex-direction: column; gap: 2px; padding: 8px;
}
.nch-tab-btn {
    display: flex; align-items: center; gap: 8px; padding: 10px 12px;
    border: none; background: transparent; color: var(--text-muted);
    cursor: pointer; border-radius: var(--r-md); font-size: 13px;
    transition: all var(--transition-fast); text-align: left;
}
.nch-tab-btn:hover { background: var(--bg-hover); color: var(--text); }
.nch-tab-btn.active { background: var(--overlay-1); color: var(--accent); font-weight: 600; }
.nch-tab-icon { width: 14px; text-align: center; }

.nch-panel {
    flex: 1; overflow-y: auto; padding: 20px 24px;
    display: flex; flex-direction: column; gap: 16px;
}
.nch-header {
    display: flex; align-items: center; gap: 12px;
    padding-bottom: 12px; border-bottom: 1px solid var(--border);
}
.nch-title {
    font-size: 16px; font-weight: 600; color: var(--text);
    display: flex; align-items: center; gap: 8px;
}
.nch-icon-accent { color: var(--accent); }
.nch-spacer { flex: 1; }
.nch-desc {
    font-size: 13px; color: var(--text-muted); margin: 0;
    padding: 8px 12px; background: var(--overlay-1); border-radius: var(--r-md);
}

/* Cards */
.nch-cards { display: flex; flex-direction: column; gap: 14px; }
.nch-card {
    border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--bg-secondary); overflow: hidden;
}
.nch-card-head {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 16px; background: var(--overlay-1);
    border-bottom: 1px solid var(--border);
}
.nch-card-title { font-size: 14px; font-weight: 600; color: var(--text); }
.nch-card-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 10px; }
.nch-card-body.nch-disabled { opacity: 0.4; pointer-events: none; }

.nch-field-row { display: flex; align-items: center; gap: 10px; }
.nch-field-label { font-size: 13px; color: var(--text-secondary); min-width: 110px; flex-shrink: 0; }
.nch-input {
    flex: 1; background: var(--bg-input); border: 1px solid var(--border);
    color: var(--text); padding: 6px 10px; border-radius: var(--r-sm);
    font-size: 13px; font-family: inherit;
}
.nch-input:focus { border-color: var(--accent); outline: none; }

.nch-checkbox-label {
    display: flex; align-items: center; gap: 8px;
    font-size: 13px; color: var(--text); cursor: pointer;
}
.nch-checkbox-label input[type="checkbox"] { accent-color: var(--accent); width: 16px; height: 16px; }

.nch-card-actions { display: flex; align-items: center; gap: 10px; margin-top: 4px; }
.nch-test-btn { min-width: 80px; }
.nch-test-result { font-size: 12px; font-weight: 500; }
.nch-test-result.nch-ok { color: var(--success); }
.nch-test-result.nch-err { color: var(--danger); }

/* Local mail server auto-detect */
.nch-local-badge {
    font-size: 11px; font-weight: 600; color: var(--success);
    background: rgba(16, 185, 129, 0.12); border-radius: var(--r-sm);
    padding: 2px 8px; margin-left: 8px;
}
.nch-local-smtp {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; border-radius: var(--r-md);
    background: rgba(16, 185, 129, 0.08); border: 1px solid rgba(16, 185, 129, 0.2);
}
.nch-local-hint { font-size: 12px; color: var(--text-secondary); }

/* Toggle switch */
.nch-toggle {
    position: relative; display: inline-block; width: 36px; height: 20px; cursor: pointer;
}
.nch-toggle input { display: none; }
.nch-toggle-slider {
    position: absolute; inset: 0; background: var(--border);
    border-radius: 10px; transition: background 0.2s;
}
.nch-toggle-slider::after {
    content: ''; position: absolute; top: 2px; left: 2px;
    width: 16px; height: 16px; background: #fff; border-radius: 50%;
    transition: transform 0.2s;
}
.nch-toggle input:checked + .nch-toggle-slider { background: var(--accent); }
.nch-toggle input:checked + .nch-toggle-slider::after { transform: translateX(16px); }

/* Triggers */
.nch-trigger-list { display: flex; flex-direction: column; gap: 2px; }
.nch-trigger-row {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 14px; border-radius: var(--r-md);
    transition: background var(--transition-fast);
}
.nch-trigger-row:hover { background: var(--overlay-1); }
.nch-trigger-icon { width: 18px; text-align: center; color: var(--text-muted); font-size: 14px; }
.nch-trigger-label { font-size: 13px; color: var(--text); }

/* History */
.nch-history-wrap { overflow-x: auto; }
.nch-table {
    width: 100%; border-collapse: collapse; font-size: 13px;
}
.nch-table thead { background: var(--bg-tertiary); }
.nch-table th {
    padding: 10px 12px; text-align: left; font-weight: 600;
    color: var(--text-muted); border-bottom: 1px solid var(--border);
}
.nch-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); color: var(--text); }
.nch-table tr:hover { background: var(--overlay-1); }
.nch-td-mono { font-family: monospace; font-size: 12px; white-space: nowrap; }
.nch-ok { color: var(--success); }
.nch-err { color: var(--danger); }
.nch-empty {
    text-align: center; padding: 40px 20px; color: var(--text-muted);
    font-size: 14px;
}

/* ═══ Rollback / Snapshots App ═══ */
.rollback-app { height: 100%; display: flex; flex-direction: column; padding: 16px; overflow-y: auto; position: relative; }
.rollback-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; flex-wrap: wrap; gap: 10px; }
.rollback-header-left { display: flex; align-items: center; gap: 14px; }
.rollback-header-right { display: flex; align-items: center; gap: 8px; }
.rollback-title { font-size: 1.1em; font-weight: 700; color: var(--text); margin: 0; display: flex; align-items: center; gap: 8px; }
.rollback-title i { color: var(--accent); }
.rollback-storage { font-size: 0.82em; color: var(--text-muted); background: var(--overlay-1); padding: 4px 10px; border-radius: var(--r-sm); }

/* Buttons */
.rollback-btn { border: none; border-radius: var(--r-sm); padding: 7px 14px; font-size: 0.85em; font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: all var(--transition-fast); background: var(--overlay-1); color: var(--text); }
.rollback-btn:hover { background: var(--overlay-2); }
.rollback-btn-primary { background: rgba(79,140,255,0.15); color: var(--accent); }
.rollback-btn-primary:hover { background: rgba(79,140,255,0.25); }
.rollback-btn-restore { background: rgba(34,197,94,0.12); color: var(--accent-green); }
.rollback-btn-restore:hover { background: rgba(34,197,94,0.22); }
.rollback-btn-danger { background: rgba(239,68,68,0.10); color: var(--danger); }
.rollback-btn-danger:hover { background: rgba(239,68,68,0.20); }
.rollback-btn-settings { background: transparent; color: var(--text-muted); padding: 7px 10px; }
.rollback-btn-settings:hover { color: var(--text); background: var(--overlay-1); }
.rollback-btn-sm { padding: 5px 12px; font-size: 0.8em; }

/* Settings panel */
.rollback-settings { background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px; margin-bottom: 16px; }
.rollback-settings-title { font-size: 0.9em; font-weight: 600; color: var(--text); margin-bottom: 12px; display: flex; align-items: center; gap: 8px; }
.rollback-settings-grid { display: flex; flex-direction: column; gap: 10px; }
.rollback-setting-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; font-size: 0.88em; color: var(--text); }

/* Toggle switch */
.rollback-toggle { position: relative; display: inline-block; width: 36px; height: 20px; cursor: pointer; flex-shrink: 0; }
.rollback-toggle input { display: none; }
.rollback-toggle-slider { position: absolute; inset: 0; background: var(--border); border-radius: 10px; transition: background 0.2s; }
.rollback-toggle-slider::after { content: ''; position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; background: #fff; border-radius: 50%; transition: transform 0.2s; }
.rollback-toggle input:checked + .rollback-toggle-slider { background: var(--accent); }
.rollback-toggle input:checked + .rollback-toggle-slider::after { transform: translateX(16px); }

.rollback-input { background: var(--bg-deep, #0f1117); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 6px 10px; color: var(--text); font-size: 0.88em; }
.rollback-input-sm { width: 70px; text-align: center; }

/* Snapshot list */
.rollback-list { display: flex; flex-direction: column; gap: 8px; flex: 1; overflow-y: auto; }

.rollback-snap-card { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); transition: all var(--transition-fast); }
.rollback-snap-card:hover { border-color: rgba(79,140,255,0.25); background: rgba(79,140,255,0.03); }
.rollback-snap-info { flex: 1; min-width: 0; }
.rollback-snap-header { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.rollback-snap-id { font-weight: 600; font-size: 0.92em; color: var(--text); white-space: nowrap; }
.rollback-snap-id i { color: var(--accent); margin-right: 4px; }
.rollback-snap-desc { font-size: 0.82em; color: var(--text-muted); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 400px; }
.rollback-snap-meta { display: flex; gap: 16px; font-size: 0.78em; color: var(--text-muted); }
.rollback-snap-meta i { margin-right: 4px; }
.rollback-snap-actions { display: flex; gap: 6px; flex-shrink: 0; margin-left: 12px; }

/* Badges */
.rollback-badge { display: inline-block; padding: 2px 8px; border-radius: var(--r-md); font-size: 0.72em; font-weight: 600; }
.rollback-badge-auto { background: rgba(79,140,255,0.12); color: var(--accent); }

/* Empty state */
.rollback-empty { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.rollback-empty i { font-size: 2.5em; margin-bottom: 12px; opacity: 0.4; }
.rollback-empty p { margin: 4px 0; }
.rollback-empty-hint { font-size: 0.82em; opacity: 0.7; }

/* Busy overlay */
.rollback-busy { position: absolute; inset: 0; background: rgba(0,0,0,0.45); display: flex; align-items: center; justify-content: center; z-index: 10; border-radius: var(--r-md); }
.rollback-busy-inner { display: flex; align-items: center; gap: 10px; background: var(--bg-secondary, #1e2030); padding: 16px 28px; border-radius: var(--r-md); color: var(--text); font-size: 0.95em; font-weight: 600; }
.rollback-busy-inner i { font-size: 1.2em; color: var(--accent); }


/* ═══════════════════════════════════════════════════════════
   Dashboard — system summary
   ═══════════════════════════════════════════════════════════ */

.dashboard-app {
    padding: 16px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    overflow-y: auto;
    height: 100%;
}

.dashboard-card {
    background: var(--overlay-1, #1e1e2e);
    border: 1px solid var(--border, #333);
    border-radius: var(--r-md, 10px);
    padding: 14px 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.dashboard-card--wide { grid-column: 1 / -1; }

.dashboard-card-title {
    font-size: 13px;
    font-weight: 600;
    color: var(--text-secondary, #aaa);
    display: flex;
    align-items: center;
    gap: 6px;
}

/* System info grid */
.dashboard-sys-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 6px 16px;
}
.dashboard-sys-grid > div { display: flex; flex-direction: column; }
.dashboard-sys-label { font-size: 11px; color: var(--text-muted, #777); }
.dashboard-sys-val   { font-size: 13px; font-weight: 500; }

/* Gauges row */
.dashboard-gauges {
    display: flex;
    justify-content: center;
    gap: 32px;
    flex-wrap: wrap;
}
.dashboard-gauge {
    display: flex;
    flex-direction: column;
    align-items: center;
    position: relative;
    width: 110px;
}
.dashboard-gauge-svg { width: 100px; height: 100px; }
.dashboard-gauge-value {
    position: absolute;
    top: 36px;
    font-size: 20px;
    font-weight: 700;
}
.dashboard-gauge-label {
    font-size: 13px;
    font-weight: 600;
    margin-top: 4px;
}
.dashboard-gauge-sub {
    font-size: 11px;
    color: var(--text-muted, #777);
    text-align: center;
}

/* Progress bar */
.dashboard-bar {
    height: 6px;
    background: var(--overlay-3, #333);
    border-radius: 3px;
    overflow: hidden;
}
.dashboard-bar-fill {
    height: 100%;
    border-radius: 3px;
    transition: width .5s ease;
}

/* Disks */
.dashboard-disks { display: flex; flex-direction: column; gap: 10px; }
.dashboard-disk {}
.dashboard-disk-head {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
    font-size: 13px;
}
.dashboard-disk-mount { font-weight: 600; }
.dashboard-disk-dev   { font-size: 11px; color: var(--text-muted, #777); margin-left: auto; }
.dashboard-disk-info  {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    color: var(--text-secondary, #aaa);
    margin-top: 3px;
}

/* Network */
.dashboard-net { display: flex; flex-direction: column; gap: 6px; }
.dashboard-net-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
}
.dashboard-net-name  { font-weight: 600; min-width: 70px; }
.dashboard-net-ip    { color: var(--text-secondary, #aaa); }
.dashboard-net-speed { margin-left: auto; font-size: 11px; color: var(--text-muted, #777); }

/* Status dot */
.dashboard-dot {
    display: inline-block;
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--text-muted, #555);
    flex-shrink: 0;
}
.dashboard-dot--on { background: var(--success, #22c55e); box-shadow: 0 0 4px var(--success, #22c55e); }

/* Docker card */
.dashboard-docker-stat {
    display: flex;
    align-items: baseline;
    gap: 6px;
}
.dashboard-big-num {
    font-size: 28px;
    font-weight: 700;
    color: var(--accent, #3b82f6);
}

/* Services list */
.dashboard-svc { display: flex; flex-direction: column; gap: 6px; }
.dashboard-svc-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
}
.dashboard-shares {
    display: flex;
    gap: 16px;
    font-size: 12px;
    color: var(--text-secondary, #aaa);
    padding-top: 8px;
    border-top: 1px solid var(--border, #333);
    margin-top: 4px;
}

/* Temperature */
.dashboard-temp {
    font-size: 12px;
    background: var(--overlay-2, #2a2a3e);
    padding: 2px 6px;
    border-radius: var(--r-sm, 4px);
    margin-right: 4px;
}

.dashboard-empty {
    font-size: 12px;
    color: var(--text-muted, #777);
    padding: 4px 0;
}

/* ═══════════════════════════════════════════════════════════
   Cron Manager (Harmonogram)
   ═══════════════════════════════════════════════════════════ */
.cron-header {
    padding: 20px;
    border-bottom: 1px solid var(--border);
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: var(--bg-surface);
    flex-shrink: 0;
}
.cron-content {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
}
.cron-table-wrap {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
}
.cron-table td { vertical-align: middle; }
.cron-loading {
    padding: 40px !important;
    text-align: center;
    opacity: 0.6;
}
.cron-schedule {
    font-size: 0.82em;
    color: var(--text-muted);
    margin-top: 2px;
    font-family: monospace;
}
.cron-cmd {
    font-family: monospace;
    font-size: 0.88em;
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cron-toggle {
    position: relative;
    display: inline-block;
    width: 36px;
    height: 18px;
    cursor: pointer;
}
.cron-toggle input { opacity: 0; width: 0; height: 0; }
.cron-toggle-slider {
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: #555;
    border-radius: 18px;
    transition: 0.3s;
}
.cron-toggle-slider:before {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    left: 2px; bottom: 2px;
    background: white;
    border-radius: 50%;
    transition: 0.3s;
}
.cron-toggle input:checked + .cron-toggle-slider { background: #22c55e; }
.cron-toggle input:checked + .cron-toggle-slider:before { transform: translateX(18px); }
.cron-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
}
.cron-dialog {
    background: var(--bg-surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    width: 540px;
    max-height: 90%;
    overflow-y: auto;
    box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.cron-dialog-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
}
.cron-dialog-close {
    background: none;
    border: none;
    color: var(--text-default);
    font-size: 1.4em;
    cursor: pointer;
    opacity: 0.6;
}
.cron-dialog-close:hover { opacity: 1; }
.cron-dialog-body { padding: 20px; }
.cron-dialog-footer {
    padding: 12px 20px;
    border-top: 1px solid var(--border);
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}
.cron-label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    margin-bottom: 4px;
    margin-top: 12px;
    opacity: 0.7;
}
.cron-label:first-child { margin-top: 0; }
.cron-presets { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 4px; }
.cron-fields-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 8px;
    margin-top: 12px;
}
.cron-field-input { width: 100%; box-sizing: border-box; text-align: center; }
.cron-preview {
    margin-top: 8px;
    padding: 8px 12px;
    background: var(--bg-default);
    border-radius: 6px;
    font-size: 0.85em;
    color: var(--text-muted);
    min-height: 20px;
}
.cron-command-input {
    width: 100%;
    box-sizing: border-box;
    resize: vertical;
    font-family: monospace;
    font-size: 0.9em;
}
.cron-empty {
    text-align: center;
    padding: 40px;
    opacity: 0.5;
}
.cron-empty i { font-size: 36px; display: block; margin-bottom: 12px; }

/* ── Cloud Backup (cb- prefix) ───────────────────────────── */
.cb-app { display: flex; height: 100%; }
.cb-sidebar { width: 200px; background: var(--overlay-1); border-right: 1px solid var(--border); flex-shrink: 0; }
.cb-nav { display: flex; flex-direction: column; padding: 8px 0; }
.cb-nav-item {
    display: flex; align-items: center; gap: 10px; padding: 10px 16px;
    cursor: pointer; color: var(--text-muted); font-size: 13px; text-decoration: none;
    border-left: 3px solid transparent; transition: all var(--transition-fast);
}
.cb-nav-item:hover { color: var(--text); background: var(--overlay-2); }
.cb-nav-item.active { color: var(--accent); border-left-color: var(--accent); background: var(--overlay-2); font-weight: 600; }
.cb-nav-item i { width: 18px; text-align: center; }
.cb-content { flex: 1; overflow: hidden; }
.cb-panel { display: none; height: 100%; overflow-y: auto; padding: 20px; }
.cb-panel.active { display: block; }

.cb-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.cb-header h3 { margin: 0; font-size: 16px; font-weight: 600; color: var(--text); display: flex; align-items: center; gap: 8px; }

.cb-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 7px 14px; border: 1px solid var(--border); border-radius: var(--r-sm);
    background: var(--overlay-1); color: var(--text); font-size: 12px;
    cursor: pointer; transition: all var(--transition-fast); white-space: nowrap;
}
.cb-btn:hover { background: var(--overlay-2); }
.cb-btn:disabled { opacity: .45; pointer-events: none; }
.cb-btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.cb-btn-primary:hover { filter: brightness(1.15); }
.cb-btn-danger { color: var(--danger); }
.cb-btn-danger:hover { background: rgba(239,68,68,.1); }

.cb-card-list { display: flex; flex-direction: column; gap: 8px; }
.cb-card {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 16px; border: 1px solid var(--border); border-radius: var(--r-md);
    background: var(--overlay-1); transition: border-color var(--transition-fast);
}
.cb-card:hover { border-color: rgba(79,140,255,.3); }
.cb-card-body { flex: 1; min-width: 0; }
.cb-card-title { font-weight: 600; font-size: 14px; color: var(--text); margin-bottom: 2px; display: flex; align-items: center; gap: 8px; }
.cb-card-meta { font-size: 12px; color: var(--text-muted); margin-bottom: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cb-card-badges { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
.cb-card-actions { display: flex; gap: 4px; flex-shrink: 0; margin-left: 12px; }

.cb-badge {
    display: inline-block; padding: 2px 8px; border-radius: 10px;
    font-size: 11px; font-weight: 500; background: var(--overlay-2); color: var(--text-muted);
}
.cb-badge-green { background: rgba(34,197,94,.12); color: var(--accent-green); }
.cb-status-ok { color: var(--accent-green); font-weight: 600; }
.cb-status-err { color: var(--danger); font-weight: 600; }
.cb-status-running { color: var(--accent-orange); font-weight: 600; }
.cb-status-none { color: var(--text-muted); }

.cb-empty { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.cb-empty i { font-size: 48px; margin-bottom: 12px; opacity: .3; display: block; }
.cb-empty p { margin: 0; font-size: 14px; }

.cb-form-card {
    margin-top: 16px; padding: 20px; border: 1px solid var(--border);
    border-radius: var(--r-md); background: var(--overlay-1);
}
.cb-form-card h4 { margin: 0 0 16px; font-size: 15px; font-weight: 600; color: var(--text); }
.cb-field { margin-bottom: 12px; }
.cb-field label { display: block; font-size: 12px; font-weight: 500; color: var(--text-muted); margin-bottom: 4px; }
.cb-field-row { display: flex; gap: 12px; }
.cb-field-row .cb-field { flex: 1; }
.cb-input {
    width: 100%; padding: 8px 10px; border: 1px solid var(--border); border-radius: var(--r-sm);
    background: var(--overlay-2); color: var(--text); font-size: 13px;
    box-sizing: border-box; outline: none; transition: border-color var(--transition-fast);
}
.cb-input:focus { border-color: var(--accent); }
select.cb-input { cursor: pointer; }
.cb-form-actions { display: flex; gap: 8px; margin-top: 16px; }

.cb-table-wrap { overflow-x: auto; }
.cb-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.cb-table thead { background: var(--overlay-1); }
.cb-table th { padding: 10px 12px; text-align: left; font-weight: 600; color: var(--text-muted); border-bottom: 1px solid var(--border); }
.cb-table td { padding: 10px 12px; border-bottom: 1px solid var(--border); color: var(--text); }
.cb-table tr:hover { background: var(--overlay-1); }
.cb-td-msg { max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-size: 12px; color: var(--text-muted); }

/* ═══ DLNA / UPnP App ═══ */
.dlna-app { padding: 16px; height: 100%; overflow-y: auto; display: flex; flex-direction: column; gap: 14px; }

.dlna-status-card {
    background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); padding: 14px 16px;
}
.dlna-status-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.dlna-status-indicator { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 0.95em; }
.dlna-status-actions { display: flex; gap: 6px; }

.dlna-status-stats {
    display: flex; gap: 18px; margin-top: 10px; padding-top: 10px;
    border-top: 1px solid var(--border); flex-wrap: wrap;
}
.dlna-stat { display: flex; align-items: center; gap: 6px; font-size: 0.85em; color: var(--text-muted); }
.dlna-stat i { color: var(--accent); font-size: 0.9em; }

.dlna-install-panel {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 40px 20px; text-align: center; background: var(--overlay-1);
    border: 2px dashed var(--border); border-radius: var(--r-lg);
}
.dlna-install-panel p { color: var(--text-muted); margin: 6px 0 16px; }

.dlna-config-panel {
    background: var(--overlay-1); border: 1px solid var(--border); border-radius: var(--r-md); padding: 16px;
    display: flex; flex-direction: column; gap: 14px;
}
.dlna-section-header h3 {
    font-size: 0.95em; font-weight: 600; display: flex; align-items: center; gap: 8px; margin: 0;
}

.dlna-form-row { display: flex; gap: 10px; align-items: center; }
.dlna-form-row > label:first-child { min-width: 140px; font-size: 0.85em; color: var(--text-muted); flex-shrink: 0; }
.dlna-form-row-top { align-items: flex-start; }

.dlna-media-dirs { display: flex; flex-direction: column; gap: 6px; flex: 1; }
.dlna-drive-row {
    display: flex; align-items: center; justify-content: space-between; gap: 10px;
    padding: 8px 12px; background: var(--overlay-2); border: 1px solid var(--border); border-radius: var(--r-md);
}
.dlna-drive-check { display: flex; align-items: center; gap: 8px; cursor: pointer; flex: 1; min-width: 0; }
.dlna-drive-check input[type="checkbox"] { accent-color: var(--accent); }
.dlna-drive-path { font-size: 0.85em; font-family: monospace; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dlna-muted { font-size: 0.85em; color: var(--text-muted); margin: 0; }

.dlna-media-types { display: flex; gap: 4px; flex-shrink: 0; }
.dlna-type-tag {
    width: 26px; height: 26px; border: 1px solid var(--border); border-radius: 4px;
    background: var(--overlay-2); color: var(--text-muted); font-size: 0.75em; font-weight: 700;
    display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all var(--transition);
}
.dlna-type-tag:hover { border-color: var(--accent); color: var(--accent); }
.dlna-type-tag.active { background: var(--accent); color: #fff; border-color: var(--accent); }

.dlna-toggle { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.dlna-toggle input { display: none; }
.dlna-toggle-slider {
    width: 38px; height: 20px; background: var(--overlay-2); border: 1px solid var(--border);
    border-radius: 10px; position: relative; transition: all var(--transition); flex-shrink: 0;
}
.dlna-toggle-slider::after {
    content: ''; position: absolute; top: 2px; left: 2px; width: 14px; height: 14px;
    background: var(--text-muted); border-radius: 50%; transition: all var(--transition);
}
.dlna-toggle input:checked + .dlna-toggle-slider { background: var(--accent); border-color: var(--accent); }
.dlna-toggle input:checked + .dlna-toggle-slider::after { left: 20px; background: #fff; }
.dlna-toggle-label { font-size: 0.85em; color: var(--text-muted); }

.dlna-form-actions { display: flex; gap: 8px; margin-top: 4px; }

.dlna-btn {
    padding: 10px 18px; border: none; border-radius: var(--r-md); font-size: 0.9em;
    font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 7px;
    transition: all var(--transition);
}
.dlna-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.dlna-btn-sm { padding: 6px 14px; font-size: 0.82em; }
.dlna-btn-primary { background: var(--accent); color: #fff; }
.dlna-btn-primary:hover:not(:disabled) { filter: brightness(1.15); }
.dlna-btn-secondary { background: var(--overlay-2); color: var(--text); border: 1px solid var(--border); }
.dlna-btn-secondary:hover:not(:disabled) { background: var(--overlay-1); border-color: var(--accent); }
.dlna-btn-danger { background: #ef4444; color: #fff; }
.dlna-btn-danger:hover:not(:disabled) { filter: brightness(1.15); }

/* ─── FM Batch Bar (floating multi-select actions) ─── */
.fm-batch-bar {
    position: absolute;
    bottom: 48px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 200;
    background: var(--bg-panel, #1e293b);
    border: 1px solid var(--border, #334155);
    border-radius: var(--r-lg);
    padding: 8px 16px;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 8px 32px rgba(0,0,0,.4);
    backdrop-filter: blur(8px);
    white-space: nowrap;
}
.fm-batch-count {
    color: var(--text-muted);
    font-size: 13px;
    margin-right: 4px;
}
.fm-batch-cancel {
    background: none;
    border: none;
    color: var(--danger);
    cursor: pointer;
    padding: 6px 10px;
    border-radius: var(--r-md);
    font-size: 13px;
    transition: all var(--transition-fast);
}
.fm-batch-cancel:hover { background: rgba(239,68,68,.12); }


/* ═══════════════════════════════════════════════════════════
   Power Management App
   ═══════════════════════════════════════════════════════════ */
.pwr-wrap { display: flex; flex-direction: column; height: 100%; background: var(--window-bg); }
.pwr-loading { display: flex; align-items: center; justify-content: center; gap: 10px; height: 100%; color: var(--text-muted); font-size: 14px; }
.pwr-error { color: var(--danger, #ef4444); }

.pwr-status-bar { display: flex; align-items: center; gap: 8px; padding: 10px 16px; background: var(--bg-surface-alt, #0f172a); border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.pwr-status-chip { display: flex; align-items: center; gap: 6px; padding: 4px 10px; background: var(--bg-elevated); border: 1px solid var(--border); border-radius: 999px; font-size: 12px; color: var(--text-primary); }

.pwr-scroll { flex: 1; overflow-y: auto; padding: 14px 16px; display: flex; flex-direction: column; gap: 12px; min-height: 0; }

.pwr-card { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-lg, 10px); overflow: hidden; flex-shrink: 0; }
.pwr-card-header { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; }
.pwr-card-header > i:first-child { font-size: 18px; margin-top: 2px; flex-shrink: 0; }
.pwr-card-title { font-size: 14px; font-weight: 600; color: var(--text-primary); }
.pwr-card-sub { font-size: 12px; color: var(--text-muted); margin-top: 2px; }

/* CPU governor grid */
.pwr-gov-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; padding: 0 16px 14px; }
.pwr-gov-btn { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 10px 8px; background: var(--bg-surface-alt); border: 2px solid transparent; border-radius: var(--r-md, 8px); cursor: pointer; transition: all 0.15s; text-align: center; color: var(--text-primary); }
.pwr-gov-btn:hover { background: var(--bg-hover); border-color: var(--border); }
.pwr-gov-btn.active { background: rgba(59,130,246,.1); border-color: #3b82f6; }
.pwr-gov-btn i { font-size: 20px; margin-bottom: 2px; }
.pwr-gov-name { font-size: 12px; font-weight: 600; }
.pwr-gov-desc { font-size: 10px; color: var(--text-muted); line-height: 1.3; }

/* Toggle switch */
.pwr-toggle { position: relative; display: inline-flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.pwr-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.pwr-toggle-track { width: 40px; height: 22px; background: var(--bg-surface-alt); border: 1px solid var(--border); border-radius: 999px; transition: background .2s, border-color .2s; position: relative; }
.pwr-toggle input:checked ~ .pwr-toggle-track { background: #3b82f6; border-color: #3b82f6; }
.pwr-toggle-thumb { position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; background: #fff; border-radius: 50%; transition: transform .2s; box-shadow: 0 1px 3px rgba(0,0,0,.3); }
.pwr-toggle input:checked ~ .pwr-toggle-track .pwr-toggle-thumb { transform: translateX(18px); }
.pwr-toggle-sm .pwr-toggle-track { width: 32px; height: 18px; }
.pwr-toggle-sm .pwr-toggle-thumb { width: 12px; height: 12px; }
.pwr-toggle-sm input:checked ~ .pwr-toggle-track .pwr-toggle-thumb { transform: translateX(14px); }

/* Info rows */
.pwr-info-row { display: flex; align-items: center; gap: 8px; padding: 8px 16px; border-top: 1px solid var(--border); font-size: 13px; background: var(--bg-surface-alt, #0f172a); }
.pwr-info-label { color: var(--text-muted); display: flex; align-items: center; gap: 6px; min-width: 90px; }
.pwr-info-val { color: var(--text-primary); flex: 1; font-family: monospace; }
.pwr-badge { padding: 2px 8px; border-radius: 999px; font-size: 11px; font-weight: 600; }
.pwr-badge-green { background: rgba(34,197,94,.15); color: #22c55e; }
.pwr-badge-gray { background: rgba(100,116,139,.15); color: #94a3b8; }
.pwr-warn { color: var(--warning, #f59e0b); gap: 8px; }

/* HDD list */
.pwr-hdd-list { padding: 0 16px 14px; display: flex; flex-direction: column; gap: 6px; }
.pwr-hdd-row { display: flex; align-items: center; gap: 10px; padding: 8px 10px; background: var(--bg-surface-alt); border-radius: var(--r-md); }
.pwr-hdd-name { flex: 1; font-size: 13px; color: var(--text-primary); }
.pwr-select { padding: 5px 8px; background: var(--window-bg); border: 1px solid var(--border); border-radius: 6px; color: var(--text-primary); font-size: 12px; cursor: pointer; }
.pwr-select:focus { border-color: #3b82f6; outline: none; }

/* Schedule */
.pwr-add-btn { display: flex; align-items: center; gap: 6px; padding: 6px 12px; background: rgba(59,130,246,.1); border: 1px solid rgba(59,130,246,.3); border-radius: var(--r-md); color: #3b82f6; font-size: 12px; cursor: pointer; transition: all .15s; flex-shrink: 0; }
.pwr-add-btn:hover { background: rgba(59,130,246,.2); }
.pwr-empty { padding: 20px 16px; text-align: center; color: var(--text-muted); font-size: 13px; display: flex; align-items: center; justify-content: center; gap: 8px; }
.pwr-sched-row { display: flex; align-items: center; gap: 10px; padding: 10px 16px; border-top: 1px solid var(--border); }
.pwr-sched-info { flex: 1; }
.pwr-sched-days { font-size: 12px; font-weight: 600; color: var(--text-primary); }
.pwr-sched-times { display: flex; gap: 14px; font-size: 12px; color: var(--text-muted); margin-top: 3px; }
.pwr-sched-times span { display: flex; align-items: center; gap: 5px; }
.pwr-icon-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: none; border: 1px solid var(--border); border-radius: var(--r-md); cursor: pointer; color: var(--text-muted); transition: all .15s; flex-shrink: 0; }
.pwr-icon-btn:hover { background: var(--bg-hover); color: var(--text-primary); }
.pwr-icon-danger:hover { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.3); color: #ef4444; }

/* Footer */
.pwr-footer { padding: 12px 16px; background: var(--bg-surface-alt); border-top: 1px solid var(--border); display: flex; justify-content: flex-end; }
.pwr-save-btn { display: flex; align-items: center; gap: 8px; padding: 9px 20px; background: #3b82f6; color: #fff; border: none; border-radius: var(--r-md); font-size: 13px; font-weight: 600; cursor: pointer; transition: background .15s; }
.pwr-save-btn:hover { background: #2563eb; }
.pwr-save-btn:disabled { opacity: .6; cursor: default; }

/* Dialog overlay */
.pwr-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.55); z-index: 300; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity .2s; }
.pwr-overlay.visible { opacity: 1; pointer-events: auto; }
.pwr-dialog { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-lg); width: 420px; max-width: calc(100% - 32px); box-shadow: 0 20px 60px rgba(0,0,0,.5); }
.pwr-dialog-header { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-bottom: 1px solid var(--border); font-weight: 600; font-size: 14px; }
.pwr-dialog-header i { font-size: 16px; }
.pwr-dialog-header span { flex: 1; }
.pwr-dialog-body { padding: 16px; display: flex; flex-direction: column; gap: 14px; }
.pwr-dialog-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 16px; border-top: 1px solid var(--border); }
.pwr-field { display: flex; flex-direction: column; gap: 6px; }
.pwr-field label { font-size: 12px; font-weight: 600; color: var(--text-muted); display: flex; align-items: center; gap: 6px; }
.pwr-field-row { display: flex; gap: 12px; }
.pwr-field-row .pwr-field { flex: 1; }
.pwr-input { padding: 8px 10px; background: var(--bg-surface-alt); border: 1px solid var(--border); border-radius: 8px; color: var(--text-primary); font-size: 13px; width: 100%; }
.pwr-input:focus { border-color: #3b82f6; outline: none; }
.pwr-day-picker { display: flex; gap: 6px; flex-wrap: wrap; }
.pwr-day-btn { cursor: pointer; }
.pwr-day-btn input { display: none; }
.pwr-day-btn span { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; background: var(--bg-surface-alt); border: 2px solid transparent; border-radius: 50%; font-size: 12px; font-weight: 600; transition: all .15s; color: var(--text-muted); }
.pwr-day-btn input:checked ~ span { background: rgba(59,130,246,.15); border-color: #3b82f6; color: #3b82f6; }
.pwr-btn-ghost { padding: 7px 14px; background: none; border: 1px solid var(--border); border-radius: var(--r-md); color: var(--text-muted); font-size: 13px; cursor: pointer; }
.pwr-btn-ghost:hover { background: var(--bg-hover); color: var(--text-primary); }
.pwr-btn-primary { display: flex; align-items: center; gap: 6px; padding: 7px 16px; background: #3b82f6; color: #fff; border: none; border-radius: var(--r-md); font-size: 13px; cursor: pointer; }
.pwr-btn-primary:hover { background: #2563eb; }

/* ─── app-btn: universal button class used across apps ─── */
.app-btn { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-md, 8px); color: var(--text-primary); font-size: 13px; cursor: pointer; transition: background .15s, border-color .15s; white-space: nowrap; }
.app-btn:hover:not(:disabled) { background: var(--bg-hover); border-color: var(--border-hover, var(--border)); }
.app-btn:disabled { opacity: .45; cursor: not-allowed; }
.app-btn-sm  { padding: 4px 10px; font-size: 12px; }
.app-btn-xs  { padding: 2px 7px; font-size: 11px; }
.app-btn-primary { background: #3b82f6; border-color: #3b82f6; color: #fff; }
.app-btn-primary:hover:not(:disabled) { background: #2563eb; border-color: #2563eb; }
.app-btn-accent  { background: rgba(124,58,237,.15); border-color: rgba(124,58,237,.4); color: #7c3aed; }
.app-btn-accent:hover:not(:disabled) { background: rgba(124,58,237,.25); }
.app-btn-danger  { background: rgba(239,68,68,.12); border-color: rgba(239,68,68,.35); color: #ef4444; }
.app-btn-danger:hover:not(:disabled) { background: rgba(239,68,68,.22); }
.app-btn-secondary { background: var(--bg-surface-alt); border-color: var(--border); color: var(--text-muted); }
.app-btn-secondary:hover:not(:disabled) { color: var(--text-primary); }

/* ─── app-input: universal input/select class used across apps ─── */
.app-input { padding: 7px 10px; background: var(--bg-default); border: 1px solid var(--border); border-radius: var(--r-md, 8px); color: var(--text-primary); font-size: 13px; font-family: inherit; outline: none; transition: border-color .15s, box-shadow .15s; }
.app-input:focus { border-color: var(--accent, #3b82f6); box-shadow: 0 0 0 2px rgba(59,130,246,.2); }
.app-input::placeholder { color: var(--text-muted); }
.app-input:disabled { opacity: .45; cursor: not-allowed; }
select.app-input { cursor: pointer; }
textarea.app-input { resize: vertical; line-height: 1.5; }

/* ─── Antivirus (ClamAV) ─── */
.av-prog-bar { background:var(--bg-default); border-radius:6px; height:6px; overflow:hidden; }
.av-prog-fill { height:100%; background:#16a34a; border-radius:6px; transition:width .3s; width:0%; }
.av-prog-indeterminate { width:30% !important; animation:av-slide 1.5s ease-in-out infinite; }
@keyframes av-slide { 0%{margin-left:-30%} 100%{margin-left:100%} }
.av-prog-msg { font-size:12px; color:var(--text-muted); margin-top:6px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.av-threat-item { font-size:11px; font-family:monospace; color:var(--text-primary); padding:2px 0; display:flex; gap:6px; align-items:flex-start; word-break:break-all; }
.av-badge-red { background:rgba(239,68,68,.15); color:#ef4444; }
/* ─── Package Registry (reg-*) ─── */
.reg-repo-row { display:flex; align-items:center; gap:10px; padding:8px 0; border-top:1px solid var(--border); }
.reg-repo-row:first-child { border-top:none; }
.reg-repo-icon { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; color:#fff; font-size:14px; flex-shrink:0; }
.reg-repo-info { flex:1; min-width:0; }
.reg-repo-name { font-size:13px; font-weight:600; color:var(--text-primary); display:flex; align-items:center; flex-wrap:wrap; gap:4px; }
.reg-repo-url  { font-size:11px; color:var(--text-muted); font-family:monospace; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.reg-repo-actions { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.reg-script-preview { background:var(--bg-default); border:1px solid var(--border); border-radius:6px; padding:10px 14px; font-family:monospace; font-size:12px; color:var(--text-primary); white-space:pre-wrap; word-break:break-all; line-height:1.6; margin:0; }

/* ═══════════════════════════════════════════════════════════
   Package Center (pm-)
   ═══════════════════════════════════════════════════════════ */
.pm-body { height:100%; overflow:hidden; background:var(--bg-default); }
.pm-layout { display:flex; height:100%; }
.pm-sidebar { width:200px; min-width:200px; background:var(--bg-elevated); border-right:1px solid var(--border); display:flex; flex-direction:column; overflow:hidden; }
.pm-logo { padding:14px 16px 10px; font-weight:700; font-size:14px; color:var(--text-primary); display:flex; align-items:center; gap:8px; border-bottom:1px solid var(--border); flex-shrink:0; }
.pm-logo i { color:var(--accent); }
.pm-nav { display:flex; flex-direction:column; gap:1px; padding:8px 8px 0; }
.pm-nav-btn, .pm-cat-btn { display:flex; align-items:center; gap:8px; padding:7px 10px; border-radius:6px; background:none; border:none; cursor:pointer; font-size:12.5px; color:var(--text-secondary); text-align:left; width:100%; transition:background .15s,color .15s; position:relative; }
.pm-nav-btn i, .pm-cat-btn i { width:14px; text-align:center; font-size:12px; }
.pm-nav-btn:hover, .pm-cat-btn:hover { background:var(--hover-overlay); color:var(--text-primary); }
.pm-nav-btn.active, .pm-cat-btn.active { background:var(--accent); color:#fff; }
.pm-nav-badge { margin-left:auto; background:rgba(255,255,255,.2); color:inherit; font-size:10px; padding:1px 6px; border-radius:99px; }
.pm-nav-btn:not(.active) .pm-nav-badge { background:var(--bg-default); color:var(--text-muted); }
.pm-nav-badge-warn { background:#f59e0b !important; color:#fff !important; }
.pm-nav-btn:not(.active) .pm-nav-badge-warn { background:#f59e0b !important; }
.pm-sidebar-sep { padding:12px 16px 4px; font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); }
.pm-sidebar-bottom { margin-top:auto; padding:10px 8px; border-top:1px solid var(--border); }
.pm-refresh-btn { width:100%; padding:7px 10px; background:none; border:1px solid var(--border); border-radius:6px; cursor:pointer; font-size:12px; color:var(--text-secondary); display:flex; align-items:center; gap:6px; transition:background .15s; }
.pm-refresh-btn:hover { background:var(--hover-overlay); color:var(--text-primary); }
.pm-main { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.pm-toolbar { padding:10px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:10px; background:var(--bg-elevated); flex-shrink:0; }
.pm-toolbar-actions { display:flex; gap:8px; margin-left:auto; }
.pm-ota-btn { padding:6px 14px; border-radius:7px; border:1px solid var(--border); background:var(--bg-default); color:var(--text-primary); font-size:12px; font-weight:500; cursor:pointer; display:flex; align-items:center; gap:6px; transition:border-color .15s,background .15s; white-space:nowrap; }
.pm-ota-btn:hover:not(:disabled) { border-color:var(--accent); background:var(--accent-bg,rgba(59,130,246,.08)); }
.pm-ota-btn:disabled { opacity:.5; cursor:not-allowed; }
.pm-ota-update-all { background:var(--accent); color:#fff; border-color:var(--accent); }
.pm-ota-update-all:hover:not(:disabled) { background:var(--accent-hover,#2563eb); }
.pm-src-btn { padding:6px 8px; min-width:unset; }
.pm-src-list { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.pm-src-item { display:flex; align-items:center; justify-content:space-between; padding:10px 12px; background:var(--bg-default); border:1px solid var(--border); border-radius:8px; gap:10px; }
.pm-src-item-left { display:flex; align-items:center; gap:10px; flex:1; min-width:0; }
.pm-src-name { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pm-src-url { font-size:11px; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pm-src-del { background:none; border:none; color:var(--text-muted); cursor:pointer; padding:4px 6px; border-radius:4px; font-size:12px; }
.pm-src-del:hover { color:var(--danger); background:var(--bg-hover); }
.pm-src-empty { text-align:center; padding:20px; color:var(--text-muted); font-size:13px; }
.pm-src-add-row { display:flex; justify-content:center; }
.pm-src-separator { border-top:1px solid var(--border); margin:16px 0; }
.pm-src-update-section {}
.pm-src-section-title { font-size:12px; font-weight:600; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.5px; }
.pm-src-radio { display:flex; align-items:center; gap:6px; cursor:pointer; font-size:13px; color:var(--text-primary); }
.pm-src-label { font-size:12px; color:var(--text-secondary); display:block; margin-bottom:4px; }
.pm-src-toggle { position:relative; display:inline-block; width:36px; height:20px; flex-shrink:0; }
.pm-src-toggle input { opacity:0; width:0; height:0; }
.pm-src-slider { position:absolute; inset:0; background:var(--bg-hover); border-radius:10px; cursor:pointer; transition:background .2s; }
.pm-src-slider:before { content:''; position:absolute; width:14px; height:14px; left:3px; top:3px; background:#fff; border-radius:50%; transition:transform .2s; }
.pm-src-toggle input:checked + .pm-src-slider { background:var(--accent); }
.pm-src-toggle input:checked + .pm-src-slider:before { transform:translateX(16px); }
.pm-search-wrap { position:relative; flex:1; max-width:320px; }
.pm-search-wrap i { position:absolute; left:10px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:12px; pointer-events:none; }
.pm-search { width:100%; padding:7px 10px 7px 30px; background:var(--bg-default); border:1px solid var(--border); border-radius:7px; font-size:13px; color:var(--text-primary); outline:none; }
.pm-search:focus { border-color:var(--accent); }
.pm-content { flex:1; overflow-y:auto; padding:16px; }
.pm-group { margin-bottom:24px; }
.pm-group-header { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); padding:0 2px 8px; display:flex; align-items:center; gap:6px; }
.pm-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(260px,1fr)); gap:10px; }
.pm-card { background:var(--bg-elevated); border:1px solid var(--border); border-radius:10px; overflow:hidden; transition:box-shadow .15s,border-color .15s; }
.pm-card:hover { border-color:var(--accent); box-shadow:0 2px 12px rgba(0,0,0,.15); }
.pm-card-core { opacity:.85; }
.pm-card-body { display:flex; gap:12px; padding:12px; cursor:pointer; }
.pm-card-icon { width:44px; height:44px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.pm-card-info { flex:1; min-width:0; }
.pm-card-name { font-size:13px; font-weight:600; color:var(--text-primary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pm-card-meta { font-size:11px; color:var(--text-muted); margin:2px 0; }
.pm-card-desc { font-size:12px; color:var(--text-secondary); line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.pm-card-deps { font-size:10px; color:var(--text-muted); margin-top:4px; font-family:monospace; }
.pm-card-footer { padding:8px 12px 10px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:flex-end; gap:6px; min-height:38px; }
.pm-btn-install { width:32px; height:32px; background:var(--accent); color:#fff; border:none; border-radius:8px; cursor:pointer; font-size:14px; display:inline-flex; align-items:center; justify-content:center; transition:opacity .15s; flex-shrink:0; }
.pm-btn-install:hover { opacity:.85; }
.pm-btn-primary { padding:8px 20px; background:var(--accent); color:#fff; border:none; border-radius:7px; cursor:pointer; font-size:13px; font-weight:600; display:inline-flex; align-items:center; gap:6px; }
.pm-btn-primary:hover { opacity:.85; }
.pm-btn-uninstall { width:32px; height:32px; background:rgba(239,68,68,.12); color:#ef4444; border:1px solid rgba(239,68,68,.25); border-radius:8px; cursor:pointer; font-size:13px; display:inline-flex; align-items:center; justify-content:center; transition:background .15s; flex-shrink:0; }
.pm-btn-uninstall:hover { background:rgba(239,68,68,.2); }
.pm-btn-update { width:32px; height:32px; background:rgba(245,158,11,.12); color:#f59e0b; border:1px solid rgba(245,158,11,.25); border-radius:8px; cursor:pointer; font-size:13px; display:inline-flex; align-items:center; justify-content:center; transition:background .15s; flex-shrink:0; }
.pm-btn-update:hover { background:rgba(245,158,11,.2); }
.pm-btn-install[disabled], .pm-btn-uninstall[disabled], .pm-btn-update[disabled] { opacity:.35; pointer-events:none; cursor:default; }
.pm-badge-core { font-size:10px; color:var(--text-muted); display:inline-flex; align-items:center; gap:4px; }
.pm-badge-core-sm { font-size:10px; background:var(--bg-default); color:var(--text-muted); padding:1px 6px; border-radius:4px; border:1px solid var(--border); }
.pm-badge-progress { font-size:11px; color:var(--text-muted); }
.pm-ring-wrap { display:flex; align-items:center; gap:8px; }
.pm-ring-svg { width:32px; height:32px; flex-shrink:0; transform:rotate(-90deg); }
.pm-ring-bg { fill:none; stroke:var(--bg-default); stroke-width:3; }
.pm-ring-fill { fill:none; stroke:var(--accent); stroke-width:3; stroke-linecap:round; transition:stroke-dashoffset .3s; }
.pm-ring-fill-done { stroke:var(--green, #22c55e); }
.pm-ring-fill-error { stroke:#ef4444; }
.pm-ring-pct { font-size:9px; fill:var(--text-secondary); text-anchor:middle; dominant-baseline:central; font-weight:600; }
.pm-ring-icon { font-size:12px; fill:var(--green, #22c55e); text-anchor:middle; dominant-baseline:central; font-weight:700; }
.pm-ring-icon-error { fill:#ef4444; }
.pm-card-busy { opacity:.85; }
.pm-error-msg { font-size:11px; color:#ef4444; display:flex; align-items:center; gap:4px; flex:1; }
.pm-loading { display:flex; align-items:center; justify-content:center; gap:10px; color:var(--text-muted); font-size:14px; padding:60px; }
.pm-empty { display:flex; align-items:center; justify-content:center; gap:10px; color:var(--text-muted); font-size:14px; padding:60px; flex-direction:column; }
.pm-empty i { font-size:32px; opacity:.4; }
.pm-detail-overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center; z-index:999; }
.pm-detail-modal { background:var(--bg-elevated); border:1px solid var(--border); border-radius:12px; width:480px; max-width:90%; display:flex; flex-direction:column; max-height:80vh; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.4); }
.pm-detail-header { display:flex; align-items:flex-start; gap:14px; padding:18px 18px 14px; border-bottom:1px solid var(--border); }
.pm-detail-icon { width:52px; height:52px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.pm-detail-title { flex:1; }
.pm-detail-title h2 { font-size:16px; font-weight:700; margin:0 0 4px; color:var(--text-primary); }
.pm-detail-sub { font-size:12px; color:var(--text-muted); display:flex; align-items:center; gap:6px; }
.pm-detail-close { background:none; border:none; cursor:pointer; color:var(--text-muted); font-size:16px; padding:4px; margin-left:auto; }
.pm-detail-close:hover { color:var(--text-primary); }
.pm-detail-body { flex:1; overflow-y:auto; padding:16px 18px; display:flex; flex-direction:column; gap:14px; }
.pm-detail-section { display:flex; flex-direction:column; gap:6px; }
.pm-detail-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); }
.pm-detail-desc { font-size:13px; color:var(--text-secondary); line-height:1.6; }
.pm-detail-deps { display:flex; flex-direction:column; gap:4px; }
.pm-dep-tag { display:inline-block; background:var(--bg-default); border:1px solid var(--border); border-radius:4px; padding:1px 7px; font-size:11px; font-family:monospace; color:var(--text-secondary); margin:1px; }
.pm-dep-pip { background:rgba(139,92,246,.08); border-color:rgba(139,92,246,.25); color:#8b5cf6; }
.pm-detail-footer { padding:14px 18px; border-top:1px solid var(--border); display:flex; align-items:center; justify-content:flex-end; gap:8px; }
.pm-status-installed { color:#22c55e; font-size:13px; display:flex; align-items:center; gap:5px; }
.pm-status-available { color:var(--accent); font-size:13px; display:flex; align-items:center; gap:5px; }
.pm-status-core { color:var(--text-muted); font-size:13px; display:flex; align-items:center; gap:5px; }

/* ─── Firewall (fw-) ─── */
.fw-body { display:flex; flex-direction:column; background:var(--bg-default); color:var(--text-primary); padding:0; overflow:hidden; height:100%; }
.fw-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; background:var(--bg-surface); flex-shrink:0; }
.fw-header-left { display:flex; flex-direction:column; gap:4px; }
.fw-header-right { display:flex; align-items:center; gap:10px; }
.fw-title { margin:0; font-size:16px; font-weight:700; display:flex; align-items:center; gap:8px; color:var(--text-primary); }
.fw-title i { color:#e05d44; }
.fw-status { font-size:13px; color:var(--text-muted); display:flex; align-items:center; gap:6px; }
.fw-toggle-label { font-size:13px; color:var(--text-muted); font-weight:500; }
.fw-dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:4px; }
.fw-dot.green { background:#22c55e; box-shadow:0 0 6px rgba(34,197,94,.5); }
.fw-dot.red { background:#ef4444; box-shadow:0 0 6px rgba(239,68,68,.5); }

/* Toggle switch */
.fw-switch { position:relative; display:inline-block; width:40px; height:22px; cursor:pointer; }
.fw-switch input { opacity:0; width:0; height:0; position:absolute; }
.fw-switch-slider { position:absolute; inset:0; background:#555; border-radius:22px; transition:background .3s; }
.fw-switch-slider::before { content:''; position:absolute; width:16px; height:16px; left:3px; bottom:3px; background:#fff; border-radius:50%; transition:transform .3s; }
.fw-switch input:checked + .fw-switch-slider { background:#22c55e; }
.fw-switch input:checked + .fw-switch-slider::before { transform:translateX(18px); }

/* Tabs */
.fw-tabs { display:flex; border-bottom:1px solid var(--border); background:var(--bg-surface); flex-shrink:0; }
.fw-tab { padding:10px 18px; background:transparent; border:none; border-bottom:2px solid transparent; color:var(--text-muted); cursor:pointer; font-size:13px; font-weight:500; transition:all .2s; display:flex; align-items:center; gap:6px; }
.fw-tab:hover { color:var(--text-primary); background:rgba(255,255,255,.04); }
.fw-tab.active { border-bottom-color:#e05d44; color:#e05d44; }

/* Content */
.fw-content { flex:1; overflow-y:auto; padding:16px 20px; }
.fw-panel { display:flex; flex-direction:column; gap:16px; }
.fw-section { background:var(--bg-surface); border:1px solid var(--border); border-radius:10px; padding:14px 16px; }
.fw-section-title { font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); margin-bottom:10px; }
.fw-section-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.fw-section-actions { display:flex; gap:6px; }

/* Preset grid */
.fw-preset-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(130px, 1fr)); gap:8px; }
.fw-preset-card { display:flex; flex-direction:column; align-items:center; gap:4px; padding:10px 6px; background:var(--bg-default); border:1px solid var(--border); border-radius:8px; cursor:pointer; transition:all .15s; text-align:center; }
.fw-preset-card:hover { border-color:var(--accent, #3b82f6); background:var(--bg-hover); transform:translateY(-1px); }
.fw-preset-card i { font-size:18px; }
.fw-preset-name { font-size:12px; font-weight:600; color:var(--text-primary); }
.fw-preset-ports { font-size:10px; font-family:var(--font-mono, monospace); color:var(--text-muted); }

/* Form */
.fw-form-row { display:flex; gap:10px; flex-wrap:wrap; align-items:flex-end; }
.fw-form-group { display:flex; flex-direction:column; gap:3px; flex:1; min-width:100px; }
.fw-form-group label { font-size:11px; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:.04em; }
.fw-form-narrow { max-width:110px; min-width:90px; }
.fw-form-custom-ip { min-width:140px; }
.fw-form-action { flex:0 0 auto; min-width:auto; }
.fw-form-hint { font-size:11px; color:var(--text-muted); margin-top:6px; }

/* Rules table */
.fw-rules-wrap { overflow-x:auto; border:1px solid var(--border); border-radius:8px; }
.fw-rules-table { width:100%; border-collapse:collapse; font-size:13px; }
.fw-rules-table thead { background:var(--bg-base); }
.fw-rules-table th { padding:8px 10px; text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); border-bottom:1px solid var(--border); white-space:nowrap; }
.fw-rules-table td { padding:8px 10px; border-bottom:1px solid var(--border-subtle, var(--border)); }
.fw-rules-table tbody tr:last-child td { border-bottom:none; }
.fw-rules-table tbody tr:hover { background:rgba(255,255,255,.03); }
.fw-mono { font-family:var(--font-mono, monospace); font-size:12px; }
.fw-comment-cell { font-size:12px; color:var(--text-muted); max-width:140px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.fw-empty-msg { padding:20px; text-align:center; color:var(--text-muted); font-size:13px; }

/* Action & Access badges */
.fw-action-badge { display:inline-block; padding:2px 8px; border-radius:4px; font-size:11px; font-weight:700; letter-spacing:.04em; }
.fw-action-badge.allow { background:rgba(34,197,94,.12); color:#22c55e; }
.fw-action-badge.deny { background:rgba(239,68,68,.12); color:#ef4444; }
.fw-action-badge.limit { background:rgba(245,158,11,.12); color:#f59e0b; }
.fw-access-badge { display:inline-block; padding:2px 8px; border-radius:4px; font-size:11px; font-weight:500; }
.fw-access-badge.lan { background:rgba(59,130,246,.10); color:#3b82f6; }
.fw-access-badge.public { background:rgba(245,158,11,.10); color:#f59e0b; }
.fw-access-badge.custom { background:rgba(139,92,246,.10); color:#8b5cf6; }

/* Fail2Ban / Banned */
.fw-banned-list { display:flex; flex-direction:column; gap:12px; }
.fw-jail { background:var(--bg-default); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.fw-jail-header { display:flex; justify-content:space-between; align-items:center; padding:10px 12px; border-bottom:1px solid var(--border-subtle, var(--border)); background:var(--bg-base); }
.fw-jail-name { font-size:13px; font-weight:600; color:var(--text-primary); display:flex; align-items:center; gap:6px; }
.fw-jail-name i { color:#ef4444; font-size:12px; }
.fw-jail-stats { display:flex; gap:12px; }
.fw-jail-stat { font-size:11px; color:var(--text-muted); }
.fw-ban-items { display:flex; flex-direction:column; }
.fw-ban-item { display:flex; justify-content:space-between; align-items:center; padding:8px 12px; border-bottom:1px solid var(--border-subtle, var(--border)); }
.fw-ban-item:last-child { border-bottom:none; }

/* ── Document Anonymizer (anon-*) ───────────────────────────────── */
.anon-app { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.anon-header { padding:12px 16px; font-size:15px; font-weight:600; color:var(--text); border-bottom:1px solid var(--border); display:flex; align-items:center; gap:8px; flex-shrink:0; }
.anon-header i { color:#0ea5e9; font-size:18px; }
.anon-body { flex:1; overflow:auto; padding:20px; display:flex; flex-direction:column; gap:16px; }

.anon-upload-zone { border:2px dashed var(--border); border-radius:12px; padding:40px 24px; text-align:center; cursor:pointer; transition:border-color .2s, background .2s; }
.anon-upload-zone:hover, .anon-drag-over { border-color:#0ea5e9; background:rgba(14,165,233,.06); }
.anon-upload-icon { font-size:36px; color:#0ea5e9; margin-bottom:8px; display:block; }
.anon-upload-zone p { margin:4px 0; color:var(--text-muted); font-size:13px; }
.anon-upload-hint { font-size:11px !important; opacity:.6; }

.anon-status { display:flex; flex-direction:column; align-items:center; gap:12px; padding:30px 0; }
.anon-progress-wrap { position:relative; width:64px; height:64px; }
.anon-progress-ring { width:64px; height:64px; transform:rotate(-90deg); }
.anon-ring-bg { fill:none; stroke:var(--border); stroke-width:4; }
.anon-ring-fg { fill:none; stroke:#0ea5e9; stroke-width:4; stroke-linecap:round; transition:stroke-dashoffset .4s ease; }
.anon-progress-pct { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:600; color:var(--text); }
.anon-status-msg { font-size:12px; color:var(--text-muted); text-align:center; max-width:400px; }

.anon-jobs-header { font-size:12px; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:.5px; padding-bottom:6px; border-bottom:1px solid var(--border-subtle, var(--border)); }
.anon-job-row { display:flex; justify-content:space-between; align-items:center; padding:10px 8px; border-bottom:1px solid var(--border-subtle, var(--border)); cursor:pointer; border-radius:6px; transition:background .15s; }
.anon-job-row:hover { background:var(--bg-hover, rgba(255,255,255,.04)); }
.anon-job-info { display:flex; align-items:center; gap:8px; min-width:0; flex:1; }
.anon-job-info i { font-size:14px; flex-shrink:0; }
.anon-job-done i { color:#22c55e; }
.anon-job-error i { color:#ef4444; }
.anon-job-processing i { color:#0ea5e9; }
.anon-job-name { font-size:13px; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.anon-job-date { font-size:11px; color:var(--text-muted); white-space:nowrap; margin-left:8px; }
.anon-job-actions { display:flex; align-items:center; gap:6px; flex-shrink:0; }
.anon-job-entities { font-size:11px; color:var(--text-muted); padding:2px 6px; background:rgba(14,165,233,.1); border-radius:4px; white-space:nowrap; }
.anon-btn { background:none; border:1px solid var(--border); border-radius:6px; padding:5px 8px; cursor:pointer; color:var(--text-muted); transition:color .15s, border-color .15s; font-size:12px; }
.anon-btn:hover { color:var(--text); border-color:var(--text-muted); }
.anon-btn-dl:hover { color:#0ea5e9; border-color:#0ea5e9; }
.anon-btn-del:hover { color:#ef4444; border-color:#ef4444; }
.anon-empty { text-align:center; color:var(--text-muted); font-size:13px; padding:20px 0; }

.anon-dep-warning { padding:10px 16px; background:rgba(245,158,11,.1); border-top:1px solid rgba(245,158,11,.3); color:#f59e0b; font-size:12px; display:flex; align-items:center; gap:8px; flex-shrink:0; }

.anon-detail { padding:16px; }
.anon-detail h3 { margin:0 0 12px; font-size:15px; }
.anon-detail p { margin:4px 0; font-size:13px; color:var(--text-muted); }
.anon-detail-table { width:100%; border-collapse:collapse; margin-top:12px; font-size:12px; }
.anon-detail-table th { text-align:left; padding:6px 8px; border-bottom:2px solid var(--border); color:var(--text-muted); font-weight:600; }
.anon-detail-table td { padding:5px 8px; border-bottom:1px solid var(--border-subtle, var(--border)); }
.anon-detail-table code { background:rgba(14,165,233,.1); padding:1px 5px; border-radius:3px; font-size:11px; color:#0ea5e9; }
.anon-cat { font-size:10px; font-weight:600; padding:2px 6px; border-radius:3px; text-transform:uppercase; }
.anon-cat-imie, .anon-cat-nazwisko, .anon-cat-lekarz { background:rgba(139,92,246,.15); color:#8b5cf6; }
.anon-cat-pesel, .anon-cat-nr_pacjenta, .anon-cat-nr_dokumentu { background:rgba(239,68,68,.15); color:#ef4444; }
.anon-cat-adres, .anon-cat-telefon, .anon-cat-email { background:rgba(14,165,233,.15); color:#0ea5e9; }
.anon-cat-data_urodzenia { background:rgba(245,158,11,.15); color:#f59e0b; }
.anon-cat-nazwa_placowki { background:rgba(16,185,129,.15); color:#10b981; }
.anon-error-msg { color:#ef4444; font-size:12px; margin-top:8px; padding:8px; background:rgba(239,68,68,.08); border-radius:6px; }

/* Batch toolbar & checkboxes */
.anon-jobs-toolbar { display:flex; align-items:center; justify-content:space-between; gap:8px; padding-bottom:6px; border-bottom:1px solid var(--border-subtle, var(--border)); }
.anon-jobs-toolbar .anon-jobs-header { border-bottom:none; padding-bottom:0; }
.anon-batch-bar { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--text-muted); }
.anon-batch-count { font-weight:600; color:var(--text); }
.anon-btn-batch-del { display:inline-flex; align-items:center; gap:4px; background:none; border:1px solid #ef4444; border-radius:6px; padding:4px 10px; cursor:pointer; color:#ef4444; font-size:12px; transition:background .15s, color .15s; }
.anon-btn-batch-del:hover { background:#ef4444; color:#fff; }
.anon-job-cb-label { display:flex; align-items:center; flex-shrink:0; padding-right:4px; }
.anon-job-cb { accent-color:#0ea5e9; width:15px; height:15px; cursor:pointer; }

/* Split-pane preview */
.anon-preview { display:flex; flex-direction:column; height:100%; overflow:hidden; }
.anon-preview-meta { display:flex; align-items:center; gap:16px; padding:10px 16px; border-bottom:1px solid var(--border); font-size:12px; color:var(--text-muted); flex-shrink:0; }
.anon-preview-meta span { display:flex; align-items:center; gap:4px; }
.anon-preview-meta i { font-size:12px; color:#0ea5e9; }
.anon-preview-pending { display:flex; align-items:center; justify-content:center; gap:8px; padding:40px; color:var(--text-muted); font-size:14px; }
.anon-preview-split { display:flex; flex:1; min-height:0; overflow:hidden; }
.anon-preview-pane { flex:1; display:flex; flex-direction:column; min-width:0; overflow:hidden; }
.anon-preview-pane-title { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); padding:8px 12px; border-bottom:1px solid var(--border); flex-shrink:0; display:flex; align-items:center; gap:6px; }
.anon-preview-pane-title i { font-size:12px; }
.anon-preview-pane-title-anon { color:#22c55e; }
.anon-preview-pane-title-anon i { color:#22c55e; }
.anon-preview-divider { width:1px; background:var(--border); flex-shrink:0; }
.anon-preview-content { flex:1; overflow:auto; position:relative; background:#e5e7eb; }
.anon-preview-iframe { width:100%; height:100%; border:none; background:#fff; }
.anon-preview-text { padding:16px 20px; font-size:14px; line-height:1.8; color:var(--text); white-space:pre-wrap; word-wrap:break-word; font-family:var(--font-family); transition:transform 0.15s ease; background:var(--card-bg); }
.anon-pdf-pages { display:flex; flex-direction:column; align-items:center; gap:8px; padding:8px; }
.anon-pdf-canvas { background:#fff; box-shadow:0 1px 4px rgba(0,0,0,.25); max-width:100%; }
.anon-preview-loading { display:flex; align-items:center; justify-content:center; padding:40px; color:var(--text-muted); }
.anon-preview-error { display:flex; align-items:center; justify-content:center; padding:40px; color:#ef4444; font-size:13px; }
.anon-zoom-bar { display:flex; align-items:center; gap:4px; margin-left:auto; }
.anon-zoom-btn { background:var(--card-bg); border:1px solid var(--border); border-radius:4px; width:26px; height:26px; display:flex; align-items:center; justify-content:center; cursor:pointer; color:var(--text-muted); font-size:11px; transition:background .15s,color .15s; }
.anon-zoom-btn:hover { background:var(--hover); color:var(--text); }
.anon-zoom-level { font-size:11px; font-weight:600; color:var(--text-muted); min-width:36px; text-align:center; }
.anon-preview-table-wrap { flex-shrink:0; max-height:200px; overflow:auto; border-top:1px solid var(--border); padding:8px 12px; }
.anon-preview-table-title { font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); padding-bottom:6px; display:flex; align-items:center; gap:6px; }
.anon-preview-table-title i { color:#0ea5e9; font-size:11px; }
.anon-preview-table-count { font-weight:400; opacity:.7; }

/* Toggle switch for replacement rows */
.anon-toggle { position:relative; display:inline-block; width:34px; height:18px; cursor:pointer; }
.anon-toggle input { opacity:0; width:0; height:0; }
.anon-toggle-slider { position:absolute; top:0; left:0; right:0; bottom:0; background:#4b5563; border-radius:18px; transition:.2s; }
.anon-toggle-slider::before { content:''; position:absolute; height:14px; width:14px; left:2px; bottom:2px; background:#fff; border-radius:50%; transition:.2s; }
.anon-toggle input:checked + .anon-toggle-slider { background:#10b981; }
.anon-toggle input:checked + .anon-toggle-slider::before { transform:translateX(16px); }
.anon-row-excluded { opacity:.45; text-decoration:line-through; }
.anon-row-excluded td { color:var(--text-muted) !important; }
.anon-regen-bar { display:flex; align-items:center; justify-content:space-between; padding:8px 0 2px; gap:12px; }
.anon-regen-hint { font-size:11px; color:var(--text-muted); display:flex; align-items:center; gap:5px; }
.anon-regen-hint i { color:#0ea5e9; }
.anon-regen-btn { padding:6px 16px; background:#0ea5e9; color:#fff; border:none; border-radius:6px; font-size:12px; font-weight:600; cursor:pointer; display:flex; align-items:center; gap:6px; white-space:nowrap; transition:background .15s; }
.anon-regen-btn:hover:not(:disabled) { background:#0284c7; }
.anon-regen-btn:disabled { opacity:.4; cursor:not-allowed; }

/* == Medical Assistant (med-*) == */
.med-app { display:flex; flex-direction:column; height:100%; font-family:var(--font-family); }
.med-header { display:flex; align-items:center; gap:10px; padding:12px 16px; border-bottom:1px solid var(--border-color); font-size:16px; font-weight:600; }
.med-header i { font-size:20px; color:#06b6d4; }
.med-disclaimer { font-size:11px; font-weight:400; color:var(--text-muted); margin-left:auto; font-style:italic; }
.med-dep-warning { display:flex; align-items:center; gap:8px; padding:10px 16px; background:rgba(245,158,11,.1); border-bottom:1px solid rgba(245,158,11,.3); color:#f59e0b; font-size:13px; }
.med-body { display:flex; flex:1; overflow:hidden; }
.med-sidebar { width:220px; min-width:220px; border-right:1px solid var(--border-color); overflow-y:auto; background:var(--bg-secondary); }
.med-sidebar-header { display:flex; align-items:center; justify-content:space-between; padding:10px 12px; font-weight:600; font-size:13px; border-bottom:1px solid var(--border-color); }
.med-btn-icon { background:none; border:none; color:var(--text-secondary); cursor:pointer; padding:4px 6px; border-radius:4px; font-size:14px; }
.med-btn-icon:hover { background:var(--bg-hover); color:var(--text-primary); }
.med-btn-icon-danger:hover { color:#ef4444; }
.med-empty-hint { color:var(--text-muted); font-size:12px; text-align:center; padding:20px 12px; }
.med-patient-row { display:flex; align-items:center; gap:8px; padding:8px 12px; cursor:pointer; font-size:13px; border-bottom:1px solid var(--border-subtle); }
.med-patient-row:hover { background:var(--bg-hover); }
.med-patient-row i { color:var(--text-muted); font-size:14px; }
.med-patient-active { background:rgba(6,182,212,.1); border-left:3px solid #06b6d4; }
.med-patient-active i { color:#06b6d4; }
.med-patient-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.med-patient-count { font-size:11px; color:var(--text-muted); background:var(--bg-tertiary); padding:1px 6px; border-radius:8px; }
.med-content { flex:1; overflow-y:auto; padding:16px; }
.med-placeholder { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; color:var(--text-muted); gap:12px; }
.med-placeholder i { font-size:48px; opacity:.3; }
.med-placeholder p { font-size:14px; }
.med-patient-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.med-patient-header h3 { margin:0; font-size:16px; display:flex; align-items:center; gap:8px; }
.med-patient-header h3 i { color:#06b6d4; }
.med-patient-actions { display:flex; gap:8px; }
.med-btn { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border:none; border-radius:6px; cursor:pointer; font-size:12px; font-weight:500; }
.med-btn-sm { padding:5px 10px; font-size:11px; }
.med-btn-upload { background:rgba(6,182,212,.15); color:#06b6d4; cursor:pointer; }
.med-btn-upload:hover { background:rgba(6,182,212,.25); }
.med-btn-danger { background:rgba(239,68,68,.1); color:#ef4444; }
.med-btn-danger:hover { background:rgba(239,68,68,.2); }
.med-empty-files { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:40px; color:var(--text-muted); gap:10px; border:2px dashed var(--border-color); border-radius:10px; margin:16px 0; }
.med-empty-files i { font-size:36px; opacity:.3; }
.med-files-header { margin-bottom:8px; }
.med-select-all { font-size:12px; color:var(--text-secondary); display:flex; align-items:center; gap:6px; cursor:pointer; }
.med-files-list { display:flex; flex-direction:column; gap:2px; margin-bottom:16px; max-height:200px; overflow-y:auto; }
.med-file-row { display:flex; align-items:center; gap:8px; padding:6px 8px; border-radius:6px; font-size:13px; }
.med-file-row:hover { background:var(--bg-hover); }
.med-file-check { cursor:pointer; }
.med-file-name { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.med-file-size { font-size:11px; color:var(--text-muted); }
.med-modes-header { font-size:13px; font-weight:600; margin-bottom:10px; padding-top:8px; border-top:1px solid var(--border-color); }
.med-modes-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:16px; }
.med-mode-card { display:flex; flex-direction:column; align-items:center; gap:6px; padding:14px 8px; border:1px solid var(--border-color); border-radius:8px; cursor:pointer; background:var(--bg-secondary); font-size:12px; text-align:center; transition:all .15s; }
.med-mode-card:hover { border-color:var(--mode-color,#06b6d4); background:color-mix(in srgb, var(--mode-color,#06b6d4) 8%, transparent); transform:translateY(-1px); }
.med-mode-card i { font-size:20px; color:var(--mode-color,#06b6d4); }
.med-mode-card span { color:var(--text-primary); }
.med-progress-box { display:flex; flex-direction:column; align-items:center; gap:8px; padding:30px; }
.med-progress-ring { width:60px; height:60px; }
.med-ring-bg { fill:none; stroke:var(--border-color); stroke-width:4; }
.med-ring-fg { fill:none; stroke:#06b6d4; stroke-width:4; stroke-linecap:round; transform:rotate(-90deg); transform-origin:center; transition:stroke-dashoffset .3s; }
.med-jobs-header { font-size:13px; font-weight:600; margin-bottom:8px; padding-top:12px; border-top:1px solid var(--border-color); }
.med-job-row { display:flex; align-items:center; justify-content:space-between; padding:8px 10px; border-radius:6px; cursor:pointer; font-size:13px; margin-bottom:2px; }
.med-job-row:hover { background:var(--bg-hover); }
.med-job-info { display:flex; align-items:center; gap:8px; }
.med-job-done i { color:#10b981; }
.med-job-error i { color:#ef4444; }
.med-job-processing i { color:#f59e0b; }
.med-job-mode { font-weight:500; }
.med-job-date { font-size:11px; color:var(--text-muted); }
.med-job-actions { display:flex; gap:4px; }
.med-result { padding:16px; }
.med-result-header { margin-bottom:16px; border-bottom:1px solid var(--border-color); padding-bottom:12px; }
.med-result-header h3 { margin:0 0 6px 0; font-size:16px; color:#06b6d4; }
.med-result-meta { font-size:12px; color:var(--text-muted); }
.med-result-text { font-size:13px; line-height:1.7; white-space:normal; padding:16px; background:var(--bg-secondary); border-radius:8px; border:1px solid var(--border-color); max-height:500px; overflow-y:auto; }
.med-result-text .med-md-h { margin:16px 0 8px; color:var(--text-primary); }
.med-result-text h2.med-md-h { font-size:16px; border-bottom:1px solid var(--border-color); padding-bottom:6px; }
.med-result-text h3.med-md-h { font-size:14px; }
.med-result-text h4.med-md-h { font-size:13px; color:#06b6d4; }
.med-md-table { width:100%; border-collapse:collapse; margin:10px 0; font-size:12px; }
.med-md-table th { background:rgba(6,182,212,.12); text-align:left; padding:6px 10px; border:1px solid var(--border-color); font-weight:600; }
.med-md-table td { padding:5px 10px; border:1px solid var(--border-color); }
.med-md-table tr:hover td { background:rgba(255,255,255,.03); }
.med-md-list { margin:6px 0; padding-left:20px; }
.med-md-list li { margin:2px 0; }
.med-md-hr { border:none; border-top:1px solid var(--border-color); margin:12px 0; }
.med-md-code { background:rgba(6,182,212,.1); padding:1px 5px; border-radius:3px; font-size:12px; }
.med-alert-icon { font-size:16px; }
.med-result-error { color:#ef4444; font-size:13px; padding:12px; background:rgba(239,68,68,.08); border-radius:6px; }

/* ═══════════════════════════════════════════════════════════
   Storage Pool Wizard (spw-*)
   ═══════════════════════════════════════════════════════════ */
.spw-wizard { display:flex; flex-direction:column; height:100%; overflow-y:auto; background:var(--bg-surface); }
.spw-header { display:flex; align-items:center; gap:12px; padding:16px 24px; font-size:18px; font-weight:600; color:var(--text-primary); border-bottom:1px solid var(--border); }
.spw-header i { color:#8b5cf6; }
.spw-body { flex:1; padding:24px 32px; max-width:780px; margin:0 auto; width:100%; }
.spw-body h3 { font-size:16px; font-weight:600; margin:0 0 12px; color:var(--text-primary); }
.spw-body h3 i { margin-right:6px; color:#8b5cf6; }
.spw-hint { color:var(--text-muted); font-size:13px; margin-bottom:18px; line-height:1.5; }

/* Step indicator */
.spw-steps { display:flex; align-items:center; justify-content:center; gap:0; padding:18px 16px; }
.spw-step { display:flex; align-items:center; gap:6px; padding:8px 14px; border-radius:20px; font-size:12px; font-weight:500; white-space:nowrap; }
.spw-step i { font-size:13px; }
.spw-step-done { background:#10b98120; color:#10b981; }
.spw-step-active { background:#8b5cf620; color:#8b5cf6; font-weight:600; }
.spw-step-pending { color:var(--text-muted); opacity:.5; }
.spw-connector { width:24px; height:2px; background:var(--border); margin:0 3px; }

/* Disk cards */
.spw-disk-list { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.spw-disk-card { display:flex; align-items:center; gap:14px; padding:12px 16px; background:var(--bg-elevated); border:2px solid var(--border); border-radius:var(--r-md); cursor:pointer; transition:border-color .15s, background .15s; }
.spw-disk-card:hover { border-color:var(--accent); background:var(--bg-hover); }
.spw-disk-selected { border-color:#8b5cf6; background:#8b5cf610; }
.spw-disk-check { font-size:18px; color:var(--text-muted); width:22px; text-align:center; flex-shrink:0; }
.spw-disk-selected .spw-disk-check { color:#8b5cf6; }
.spw-disk-info { flex:1; min-width:0; }
.spw-disk-name { font-weight:600; font-size:13px; color:var(--text-primary); }
.spw-disk-name i { margin-right:4px; color:var(--text-muted); }
.spw-disk-detail { font-size:12px; color:var(--text-muted); margin-top:2px; }
.spw-disk-size { font-weight:600; font-size:14px; color:var(--text-primary); flex-shrink:0; }
.spw-disk-usb { border-color:rgba(245,158,11,0.3); }
.spw-usb-warn { font-size:11px; color:var(--warn,#f59e0b); margin-top:4px; padding:3px 8px; background:rgba(245,158,11,0.1); border-radius:var(--r-sm,4px); display:inline-block; }
.spw-usb-warn i { margin-right:4px; }
.spw-usb-raid-block { background:rgba(245,158,11,0.08); border:1px solid rgba(245,158,11,0.25); border-radius:var(--r-md); padding:20px; margin:16px 0; color:var(--text-secondary); }
.spw-usb-raid-block p { margin:0 0 10px; }
.spw-usb-raid-block ul { margin:0; padding-left:20px; }
.spw-usb-raid-block li { margin:4px 0; }

/* RAID level cards */
.spw-raid-list { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.spw-raid-card { display:flex; align-items:center; gap:14px; padding:14px 16px; background:var(--bg-elevated); border:2px solid var(--border); border-radius:var(--r-md); cursor:pointer; transition:border-color .15s; }
.spw-raid-card:hover:not(.spw-raid-disabled) { border-color:var(--accent); }
.spw-raid-selected { border-color:#8b5cf6; background:#8b5cf610; }
.spw-raid-disabled { opacity:.45; cursor:not-allowed; }
.spw-raid-icon { font-size:22px; width:30px; text-align:center; flex-shrink:0; }
.spw-raid-info { flex:1; min-width:0; }
.spw-raid-label { font-weight:600; font-size:13px; color:var(--text-primary); }
.spw-raid-desc { font-size:12px; color:var(--text-muted); margin-top:2px; line-height:1.4; }
.spw-raid-warn { font-size:11px; color:#ef4444; margin-top:4px; font-weight:500; }
.spw-raid-cap { font-weight:600; font-size:14px; color:var(--text-primary); flex-shrink:0; min-width:70px; text-align:right; }

/* Form */
.spw-form { display:flex; flex-direction:column; gap:18px; }
.spw-field label { display:block; font-size:13px; font-weight:600; color:var(--text-primary); margin-bottom:6px; }
.spw-input { width:100%; padding:9px 12px; background:var(--bg-elevated); border:1px solid var(--border); border-radius:var(--r-md); color:var(--text-primary); font-size:13px; outline:none; box-sizing:border-box; }
.spw-input:focus { border-color:#8b5cf6; box-shadow:0 0 0 2px #8b5cf620; }
.spw-input:disabled { opacity:.5; }
.spw-input-indent { margin-top:8px; margin-left:24px; width:calc(100% - 24px); }
.spw-radio-group { display:flex; flex-direction:column; gap:6px; }
.spw-radio { display:flex; align-items:center; gap:8px; padding:10px 14px; background:var(--bg-elevated); border:2px solid var(--border); border-radius:var(--r-md); cursor:pointer; font-size:13px; transition:border-color .15s; }
.spw-radio:hover { border-color:var(--accent); }
.spw-radio-active { border-color:#8b5cf6; background:#8b5cf610; }
.spw-radio-desc { color:var(--text-muted); font-size:12px; margin-left:4px; }
.spw-checkbox-label { display:flex; align-items:center; gap:6px; font-weight:500 !important; cursor:pointer; }

/* Summary */
.spw-summary { background:var(--bg-elevated); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; margin-bottom:16px; }
.spw-summary-row { display:flex; justify-content:space-between; padding:10px 16px; border-bottom:1px solid var(--border); font-size:13px; }
.spw-summary-row:last-child { border-bottom:none; }
.spw-summary-row span { color:var(--text-muted); }
.spw-summary-row strong { color:var(--text-primary); }
.spw-warning { background:#ef444415; border:1px solid #ef444440; border-radius:var(--r-md); padding:12px 16px; color:#ef4444; font-size:13px; font-weight:500; margin-bottom:16px; }
.spw-warning i { margin-right:6px; }

/* Progress log */
.spw-progress-log { background:var(--bg-elevated); border:1px solid var(--border); border-radius:var(--r-md); padding:16px; max-height:300px; overflow-y:auto; font-family:monospace; font-size:12px; margin-bottom:20px; }
.spw-log-step { color:#10b981; padding:4px 0; font-weight:500; }
.spw-log-step i { margin-right:6px; }
.spw-log-error { color:#ef4444; padding:4px 0; font-weight:500; }
.spw-log-error i { margin-right:6px; }
.spw-log-line { color:var(--text-muted); padding:1px 0; }

/* Done states */
.spw-done-success { text-align:center; padding:32px 0; color:#10b981; }
.spw-done-success i { margin-bottom:12px; }
.spw-done-error { text-align:center; padding:32px 0; color:#ef4444; }
.spw-done-error i { margin-bottom:12px; }
.spw-done-title { font-size:20px; font-weight:700; margin:8px 0; color:var(--text-primary); }
.spw-done-subtitle { font-size:13px; color:var(--text-muted); margin-bottom:20px; }

/* Buttons */
.spw-actions { display:flex; gap:10px; justify-content:flex-end; padding-top:20px; border-top:1px solid var(--border); margin-top:20px; }
.spw-btn { padding:9px 20px; border-radius:var(--r-md); font-size:13px; font-weight:600; border:none; cursor:pointer; display:inline-flex; align-items:center; gap:6px; transition:opacity .15s; }
.spw-btn:disabled { opacity:.4; cursor:not-allowed; }
.spw-btn:hover:not(:disabled) { opacity:.85; }
.spw-btn-primary { background:#8b5cf6; color:#fff; }
.spw-btn-secondary { background:var(--bg-elevated); color:var(--text-primary); border:1px solid var(--border); }
.spw-btn-danger { background:#ef4444; color:#fff; }

/* Loading & empty states */
.spw-loading { text-align:center; padding:60px 0; color:var(--text-muted); }
.spw-loading i { display:block; margin-bottom:12px; color:#8b5cf6; }
.spw-empty { text-align:center; padding:60px 0; color:var(--text-muted); }

/* ── Storage Manager: Overview (smo-*) ─────────────────── */
.smo-cards { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:20px; }
.smo-card { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:10px; padding:18px 22px; min-width:170px; flex:1; }
.smo-card-icon { font-size:24px; margin-bottom:8px; }
.smo-card-value { font-size:22px; font-weight:700; color:var(--text-primary); }
.smo-card-title { font-size:12px; color:var(--text-secondary); margin-top:2px; }
.smo-card-sub { font-size:11px; color:var(--text-tertiary, var(--text-secondary)); margin-top:4px; }

.smo-section { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:10px; padding:16px; margin-bottom:16px; }
.smo-section-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.smo-section-header h4 { margin:0; font-size:14px; font-weight:600; }
.smo-link-btn { background:none; border:none; color:var(--accent); cursor:pointer; font-size:13px; padding:4px 8px; border-radius:4px; }
.smo-link-btn:hover { background:var(--bg-hover); }

.smo-pool-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:12px; }
.smo-pool-card { background:var(--bg-primary); border:1px solid var(--border-color); border-radius:8px; padding:14px; }
.smo-pool-header { display:flex; align-items:center; gap:8px; margin-bottom:8px; font-size:14px; }
.smo-pool-bar-wrap { height:6px; background:var(--bg-tertiary, #2a2a2e); border-radius:3px; overflow:hidden; }
.smo-pool-bar { height:100%; border-radius:3px; transition:width .3s; }
.smo-pool-stats { display:flex; justify-content:space-between; font-size:12px; color:var(--text-secondary); margin-top:4px; }
.smo-pool-meta { display:flex; gap:12px; font-size:11px; color:var(--text-muted, var(--text-secondary)); margin-top:8px; }
.smo-pool-meta i { margin-right:3px; }

.smo-badge { display:inline-block; font-size:11px; padding:2px 8px; border-radius:10px; background:var(--bg-tertiary, #2a2a2e); color:var(--text-secondary); }
.smo-badge-blue { background:rgba(59,130,246,0.15); color:#60a5fa; }
.smo-dot { display:inline-block; width:8px; height:8px; border-radius:50%; }
.smo-dot-green { background:#2ecc71; }
.smo-dot-red { background:#e74c3c; }

.smo-table { width:100%; border-collapse:collapse; font-size:13px; }
.smo-table th { text-align:left; padding:8px; border-bottom:2px solid var(--border-color); font-weight:600; }
.smo-table td { padding:8px; border-bottom:1px solid var(--border-color); }
.smo-table tr:last-child td { border-bottom:none; }

/* ── Storage Manager: Pools section (smp-*) ──────────── */
.smp-layout { display:flex; height:100%; overflow:hidden; }
.smp-list { width:380px; min-width:340px; border-right:1px solid var(--border-color); overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; }
.smp-detail { flex:1; overflow-y:auto; padding:20px; }

.smp-toolbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.smp-btn { background:var(--bg-secondary); border:1px solid var(--border-color); color:var(--text-primary); padding:6px 12px; border-radius:6px; cursor:pointer; font-size:13px; display:inline-flex; align-items:center; gap:6px; }
.smp-btn:hover { background:var(--bg-hover); }
.smp-btn-accent { background:var(--accent); color:#fff; border-color:var(--accent); }
.smp-btn-accent:hover { filter:brightness(1.1); }
.smp-btn-danger { background:#ef4444; color:#fff; border-color:#ef4444; }
.smp-btn-danger:hover { filter:brightness(1.1); }

.smp-card { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:10px; padding:14px 16px; cursor:pointer; transition:border-color .15s, background .15s; }
.smp-card:hover { border-color:var(--accent); background:var(--bg-hover); }
.smp-card-active { border-color:var(--accent); background:var(--bg-active, var(--bg-hover)); box-shadow:0 0 0 1px var(--accent); }

.smp-card-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.smp-card-name { display:flex; align-items:center; font-size:14px; }
.smp-card-status { display:flex; align-items:center; gap:6px; font-size:12px; }
.smp-card-badges { display:flex; gap:6px; flex-wrap:wrap; }
.smp-card-usage { display:flex; justify-content:space-between; font-size:12px; color:var(--text-secondary); }

.smp-detail-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100%; color:var(--text-muted, var(--text-secondary)); font-size:14px; text-align:center; }
.smp-detail-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.smp-detail-header h3 { margin:0; font-size:18px; }

.smp-detail-section { margin-bottom:20px; }
.smp-detail-section h4 { margin:0 0 10px; font-size:13px; font-weight:700; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.3px; }

.smp-info-grid { display:flex; flex-direction:column; gap:6px; }
.smp-info-row { display:flex; justify-content:space-between; font-size:13px; padding:6px 0; border-bottom:1px solid var(--border-color); }
.smp-info-row:last-child { border-bottom:none; }
.smp-info-row span:first-child { color:var(--text-secondary); }
.smp-info-row code { background:var(--bg-tertiary, #2a2a2e); padding:2px 6px; border-radius:4px; font-size:12px; }

.smp-disk-chips { display:flex; gap:8px; flex-wrap:wrap; }
.smp-disk-chip { display:inline-flex; align-items:center; gap:6px; background:var(--bg-tertiary, #2a2a2e); padding:6px 12px; border-radius:6px; font-size:12px; font-family:monospace; }

.smp-shares-list { display:flex; flex-direction:column; gap:4px; }
.smp-share-row { display:flex; align-items:center; gap:10px; padding:8px 10px; background:var(--bg-primary); border-radius:6px; font-size:13px; }

.smp-detail-actions { display:flex; gap:10px; margin-top:24px; padding-top:16px; border-top:1px solid var(--border-color); }

/* ── Security Advisor ─────────────────────────────────────────── */
.sa-container { padding:24px; max-width:800px; margin:0 auto; }
.sa-header { display:flex; align-items:center; gap:28px; margin-bottom:28px; padding-bottom:24px; border-bottom:1px solid var(--border-color); }
.sa-score-ring { position:relative; width:120px; height:120px; flex-shrink:0; }
.sa-ring-svg { width:100%; height:100%; transform:rotate(-90deg); }
.sa-ring-bg { fill:none; stroke:var(--bg-tertiary); stroke-width:8; }
.sa-ring-fg { fill:none; stroke:#22c55e; stroke-width:8; stroke-linecap:round; transition:stroke-dashoffset 0.8s ease, stroke 0.3s; }
.sa-score-text { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-size:32px; font-weight:700; color:var(--text-primary); }
.sa-summary h2 { margin:0 0 6px; font-size:18px; }
.sa-summary p { margin:0 0 14px; color:var(--text-secondary); font-size:14px; }
.sa-results { display:flex; flex-direction:column; gap:6px; }
.sa-check { display:flex; align-items:flex-start; gap:12px; padding:12px 14px; border-radius:8px; background:var(--bg-secondary); }
.sa-check > i { margin-top:2px; font-size:16px; flex-shrink:0; }
.sa-check-content { flex:1; min-width:0; }
.sa-check-title { font-size:14px; font-weight:500; display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.sa-check-desc { font-size:12px; color:var(--text-secondary); margin-top:4px; }
.sa-badge { font-size:10px; padding:1px 6px; border-radius:4px; color:#fff; font-weight:600; text-transform:uppercase; }
.sa-failed { border-left:3px solid #ef4444; }
.sa-passed { opacity:0.7; }
.sa-fix-btn { flex-shrink:0; align-self:center; }
.sa-confirm-overlay { position:absolute; inset:0; background:rgba(0,0,0,.55); display:flex; align-items:center; justify-content:center; z-index:200; border-radius:8px; }
.sa-confirm-dialog { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:12px; padding:28px; max-width:420px; text-align:center; box-shadow:0 8px 32px rgba(0,0,0,.4); }
.sa-confirm-icon { font-size:36px; color:#f59e0b; margin-bottom:12px; }
.sa-confirm-title { font-size:16px; font-weight:700; margin-bottom:8px; color:var(--text-primary); }
.sa-confirm-msg { font-size:13px; color:var(--text-secondary); line-height:1.5; margin-bottom:20px; }
.sa-confirm-btns { display:flex; gap:10px; justify-content:center; }
.sa-confirm-btns .btn { min-width:100px; }


/* ── Photos AI (pai-*) ── */
.pai-loading { display:flex; align-items:center; justify-content:center; height:100%; gap:10px; color:var(--text-secondary); }
.pai-error { padding:20px; color:var(--error); }
.pai-app { display:flex; height:100%; overflow:hidden; }
.pai-sidebar { width:200px; min-width:200px; border-right:1px solid var(--border-color); padding:10px 0; overflow-y:auto; background:var(--bg-secondary); }
.pai-sidebar-section { padding:8px 12px; }
.pai-sidebar-title { font-size:11px; font-weight:700; text-transform:uppercase; color:var(--text-secondary); margin-bottom:6px; letter-spacing:.5px; }
.pai-nav { display:flex; align-items:center; gap:8px; padding:7px 12px; border-radius:6px; cursor:pointer; font-size:13px; color:var(--text-primary); transition:background .15s; }
.pai-nav:hover { background:var(--bg-hover); }
.pai-nav.active { background:var(--accent-color); color:#fff; }
.pai-nav i { width:16px; text-align:center; font-size:13px; }
.pai-scan-controls { margin-top:4px; }
.pai-scan-btn-row { display:flex; gap:6px; margin-top:6px; }
.pai-scan-btn-row .btn { flex:1; font-size:12px; }
.pai-scan-status { font-size:12px; display:flex; align-items:center; gap:6px; padding:4px 0; color:var(--text-secondary); }
.pai-scan-settings { margin-top:10px; border-top:1px solid var(--border-color); padding-top:8px; }
.pai-setting-row { display:flex; align-items:center; gap:6px; font-size:12px; color:var(--text-secondary); cursor:pointer; }
.pai-setting-row input[type="checkbox"] { margin:0; }
.pai-scan-progress { margin-top:8px; }
.pai-progress-bar { height:4px; background:var(--bg-tertiary); border-radius:2px; overflow:hidden; }
.pai-progress-fill { height:100%; width:0; background:var(--accent-color); border-radius:2px; transition:width .3s; }
.pai-progress-text { font-size:11px; color:var(--text-secondary); margin-top:4px; }
.pai-main { flex:1; overflow-y:auto; padding:16px; }

/* Install */
.pai-install { text-align:center; max-width:460px; margin:60px auto; }
.pai-install-icon { margin-bottom:16px; }
.pai-install h2 { margin:0 0 8px; }
.pai-install p { color:var(--text-secondary); margin-bottom:20px; }
.pai-deps-grid { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-bottom:20px; }
.pai-dep { padding:6px 12px; border-radius:6px; background:var(--bg-secondary); border:1px solid var(--border-color); font-size:13px; }
.pai-dep i.fa-xmark { color:#ef4444; }
.pai-dep i.fa-check { color:#22c55e; }
.pai-dep-ok { opacity:.7; }
.pai-install-btn { font-size:15px; padding:10px 32px; }

/* Dashboard */
.pai-dashboard { max-width:700px; }
.pai-dashboard h2 { margin:0 0 20px; display:flex; align-items:center; gap:10px; }
.pai-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.pai-stat { background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:10px; padding:16px; text-align:center; }
.pai-stat-val { font-size:28px; font-weight:700; color:var(--accent-color); }
.pai-stat-label { font-size:12px; color:var(--text-secondary); margin-top:4px; }
.pai-top-tags { margin-top:24px; }
.pai-top-tags h3 { margin:0 0 10px; font-size:14px; }
.pai-tag-chips { display:flex; flex-wrap:wrap; gap:6px; }
.pai-chip { display:inline-flex; align-items:center; gap:4px; padding:4px 10px; border-radius:12px; background:var(--bg-secondary); border:1px solid var(--border-color); font-size:12px; }
.pai-chip small { color:var(--text-secondary); }
.pai-chip-click { cursor:pointer; transition:background .15s; }
.pai-chip-click:hover { background:var(--accent-color); color:#fff; }

/* People */
.pai-people-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:14px; }
.pai-person-card { text-align:center; cursor:pointer; padding:12px 8px; border-radius:10px; transition:background .15s; }
.pai-person-card:hover { background:var(--bg-hover); }
.pai-person-avatar { width:80px; height:80px; margin:0 auto 8px; border-radius:50%; overflow:hidden; background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center; }
.pai-person-avatar img { width:100%; height:100%; object-fit:cover; }
.pai-person-avatar i { font-size:32px; color:var(--text-secondary); }
.pai-person-name { font-size:13px; font-weight:600; cursor:text; }
.pai-person-count { font-size:11px; color:var(--text-secondary); margin-top:2px; }

/* Albums */
.pai-albums-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:14px; }
.pai-album-card { cursor:pointer; padding:14px; border-radius:10px; background:var(--bg-secondary); border:1px solid var(--border-color); text-align:center; transition:transform .15s,box-shadow .15s; }
.pai-album-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.15); }
.pai-album-icon { width:56px; height:56px; margin:0 auto 8px; border-radius:50%; background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.pai-album-icon i { font-size:22px; color:var(--text-secondary); }
.pai-album-face { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.pai-album-name { font-size:13px; font-weight:600; }
.pai-album-count { font-size:11px; color:var(--text-secondary); margin-top:2px; }

/* Tags */
.pai-tags-view { max-width:700px; }
.pai-tags-view h3 { margin:0 0 12px; }

/* Search */
.pai-search-view { max-width:700px; }
.pai-search-box { display:flex; align-items:center; gap:10px; padding:10px 14px; background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:8px; margin-bottom:16px; }
.pai-search-box i { color:var(--text-secondary); }
.pai-search-input { flex:1; border:none; background:transparent; outline:none; font-size:14px; color:var(--text-primary); }
.pai-search-results { min-height:100px; }

/* Photo grid */
.pai-photo-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:6px; }
.pai-photo-item { aspect-ratio:1; overflow:hidden; border-radius:6px; cursor:pointer; background:var(--bg-tertiary); }
.pai-photo-item img { width:100%; height:100%; object-fit:cover; transition:transform .2s; }
.pai-photo-item:hover img { transform:scale(1.05); }
.pai-back-btn { margin-bottom:8px; }
.pai-grid-count { font-size:13px; color:var(--text-secondary); }
.pai-empty { display:flex; flex-direction:column; align-items:center; justify-content:center; height:60%; gap:12px; color:var(--text-secondary); }

/* Merge suggestions */
.pai-merge-list { display:flex; flex-direction:column; gap:12px; max-width:600px; }
.pai-merge-card {
  background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:12px;
  padding:16px; transition:opacity .3s;
}
.pai-merge-pair { display:flex; align-items:center; justify-content:center; gap:16px; margin-bottom:12px; }
.pai-merge-person { text-align:center; min-width:90px; }
.pai-merge-avatar {
  width:64px; height:64px; margin:0 auto 6px; border-radius:50%; overflow:hidden;
  background:var(--bg-tertiary); display:flex; align-items:center; justify-content:center;
}
.pai-merge-avatar img { width:100%; height:100%; object-fit:cover; }
.pai-merge-name { font-size:13px; font-weight:600; }
.pai-merge-arrow { text-align:center; color:var(--text-secondary); font-size:18px; }
.pai-merge-conf { font-size:11px; color:var(--accent-color); margin-top:2px; font-weight:600; }
.pai-merge-actions { display:flex; gap:8px; justify-content:center; }

/* ═══════════════════════════════════════════════════════════════
   Video Station  (vs-)
   ═══════════════════════════════════════════════════════════════ */

.vs-wrap { display:flex; height:100%; overflow:hidden; }
.vs-sidebar {
  width:200px; min-width:200px; border-right:1px solid var(--border-color);
  display:flex; flex-direction:column; background:var(--bg-secondary); overflow-y:auto;
}
.vs-sidebar-section { padding:12px 14px 4px; font-size:11px; text-transform:uppercase;
  letter-spacing:.5px; color:var(--text-secondary); font-weight:600; }
.vs-sidebar-item {
  padding:8px 14px; cursor:pointer; display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--text-primary); transition:background .15s;
}
.vs-sidebar-item:hover { background:var(--bg-hover); }
.vs-sidebar-item.active { background:var(--accent-color); color:#fff; border-radius:6px; margin:0 6px; }
.vs-sidebar-item i { width:16px; text-align:center; opacity:.7; }
.vs-main { flex:1; display:flex; flex-direction:column; overflow:hidden; min-width:0; min-height:0; }

/* Toolbar */
.vs-toolbar {
  display:flex; align-items:center; gap:10px; padding:10px 16px;
  border-bottom:1px solid var(--border-color); flex-shrink:0;
}
.vs-toolbar h2 { margin:0; font-size:16px; font-weight:600; }
.vs-search {
  margin-left:auto; padding:6px 10px; border:1px solid var(--border-color);
  border-radius:6px; background:var(--bg-primary); color:var(--text-primary);
  font-size:13px; width:200px;
}
.vs-sort {
  padding:6px 8px; border:1px solid var(--border-color); border-radius:6px;
  background:var(--bg-primary); color:var(--text-primary); font-size:13px;
}
.vs-scan-btn {
  padding:6px 12px; border:none; border-radius:6px; cursor:pointer;
  background:var(--accent-color); color:#fff; font-size:13px; display:flex; align-items:center; gap:6px;
}
.vs-scan-btn:disabled { opacity:.5; cursor:not-allowed; }

/* Grid */
.vs-content { flex:1; overflow-y:auto; padding:16px; min-height:0; }
.vs-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
  gap:16px;
}
.vs-card {
  cursor:pointer; border-radius:8px; overflow:hidden;
  background:var(--bg-secondary); border:1px solid var(--border-color);
  transition:transform .15s, box-shadow .15s;
}
.vs-card:hover { transform:translateY(-2px); box-shadow:0 4px 12px rgba(0,0,0,.2); }
.vs-thumb {
  position:relative; width:100%; padding-top:56.25%; background:#111;
  overflow:hidden;
}
.vs-thumb img {
  position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover;
}
.vs-thumb-placeholder {
  position:absolute; top:0; left:0; width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  color:var(--text-secondary); font-size:32px;
}
.vs-duration {
  position:absolute; bottom:6px; right:6px; background:rgba(0,0,0,.8);
  color:#fff; font-size:11px; padding:2px 6px; border-radius:4px; font-weight:600;
}
.vs-progress-bar {
  position:absolute; bottom:0; left:0; height:3px; background:var(--accent-color);
  transition:width .2s;
}
.vs-watched-badge {
  position:absolute; top:6px; right:6px; color:#22c55e; font-size:16px;
  text-shadow:0 1px 3px rgba(0,0,0,.5);
}
.vs-card-info { padding:8px 10px; }
.vs-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden;
  text-overflow:ellipsis; margin-bottom:2px; }
.vs-meta { font-size:11px; color:var(--text-secondary); white-space:nowrap;
  overflow:hidden; text-overflow:ellipsis; }

/* Collections */
.vs-coll-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  gap:16px;
}
.vs-coll-card {
  cursor:pointer; border-radius:8px; overflow:hidden;
  background:var(--bg-secondary); border:1px solid var(--border-color);
  transition:transform .15s;
}
.vs-coll-card:hover { transform:translateY(-2px); }
.vs-coll-cover { position:relative; width:100%; padding-top:56.25%; background:#111; }
.vs-coll-cover img { position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover; }
.vs-coll-info { padding:10px 12px; }
.vs-coll-name { font-size:14px; font-weight:600; margin-bottom:2px; }
.vs-coll-meta { font-size:12px; color:var(--text-secondary); }

/* Folder settings */
.vs-folders { max-width:600px; padding:16px; }
.vs-folder-list { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.vs-folder-item {
  display:flex; align-items:center; gap:10px; padding:8px 12px;
  background:var(--bg-secondary); border:1px solid var(--border-color); border-radius:6px;
}
.vs-folder-item span { flex:1; font-size:13px; word-break:break-all; }
.vs-folder-item button { border:none; background:none; color:var(--text-secondary);
  cursor:pointer; font-size:14px; }
.vs-folder-item button:hover { color:var(--danger-color); }
.vs-folder-add { display:flex; gap:8px; }
.vs-folder-add input {
  flex:1; padding:6px 10px; border:1px solid var(--border-color); border-radius:6px;
  background:var(--bg-primary); color:var(--text-primary); font-size:13px;
}
.vs-folder-add button {
  padding:6px 14px; border:none; border-radius:6px; cursor:pointer;
  background:var(--accent-color); color:#fff; font-size:13px;
}

/* Scan progress */
.vs-scan-bar { margin:8px 16px; }
.vs-scan-track {
  width:100%; height:4px; background:var(--bg-tertiary); border-radius:2px; overflow:hidden;
}
.vs-scan-fill { height:100%; background:var(--accent-color); transition:width .3s; }
.vs-scan-label { font-size:11px; color:var(--text-secondary); margin-top:2px; }

/* Player overlay */
.vs-player-overlay {
  position:fixed; top:0; left:0; width:100vw; height:100vh;
  background:rgba(0,0,0,.95); z-index:10000; display:flex; flex-direction:column;
  overflow:hidden;
}
.vs-player-close {
  background:none; border:none;
  color:#fff; font-size:20px; cursor:pointer; opacity:.7;
  transition:opacity .2s; padding:4px 8px;
}
.vs-player-close:hover { opacity:1; }
.vs-player-title {
  color:#fff; font-size:14px;
  font-weight:500; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.vs-player-video {
  max-width:100%; max-height:100%; outline:none;
}

/* Empty state */
.vs-empty {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:60%; gap:12px; color:var(--text-secondary);
}
.vs-empty i { font-size:48px; opacity:.3; }

/* Install screen */
.vs-install-screen {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; gap:16px; color:var(--text-secondary);
}
.vs-install-screen i { font-size:64px; opacity:.3; }
.vs-install-screen h3 { margin:0; color:var(--text-primary); }
.vs-install-btn {
  padding:10px 24px; border:none; border-radius:8px; cursor:pointer;
  background:var(--accent-color); color:#fff; font-size:14px; font-weight:600;
}

/* Stats bar */
.vs-stats { display:flex; gap:16px; padding:4px 16px 0; font-size:11px; color:var(--text-secondary); }

@media (max-width:768px) {
  .vs-sidebar { width:140px; min-width:140px; }
  .vs-grid { grid-template-columns:repeat(auto-fill, minmax(150px, 1fr)); }
}

/* VS poster grid — narrower cards when posters are shown */
.vs-grid:has(.vs-card-poster) { grid-template-columns:repeat(auto-fill, minmax(160px, 1fr)); }

/* ── Video Station: info modal actions ─────────────────────────── */
.vs-info-actions { display:flex; gap:8px; flex-wrap:wrap; margin-top:4px; }
.vs-info-tmdb-btn, .vs-info-rename-btn {
    padding:8px 14px; border:none; border-radius:6px; cursor:pointer;
    font-size:13px; font-family:inherit; display:flex; align-items:center; gap:6px;
}
.vs-info-tmdb-btn { background:var(--accent-color); color:#fff; }
.vs-info-tmdb-btn:hover { filter:brightness(1.15); }
.vs-info-rename-btn { background:var(--bg-tertiary); color:var(--text-primary); }
.vs-info-rename-btn:hover { background:var(--bg-hover); }

/* ── Video Station: rename dialog ──────────────────────────────── */
.vs-rename-overlay { position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:9999;
    display:flex; align-items:center; justify-content:center; }
.vs-rename-dialog { background:var(--bg-secondary); border-radius:12px; width:420px;
    max-width:90vw; padding:0; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.vs-rename-header { display:flex; justify-content:space-between; align-items:center;
    padding:16px 20px; border-bottom:1px solid var(--border-color); font-weight:600; font-size:15px; }
.vs-rename-close { background:none; border:none; color:var(--text-secondary); cursor:pointer;
    font-size:16px; padding:4px; }
.vs-rename-close:hover { color:var(--text-primary); }
.vs-rename-body { padding:20px; }
.vs-rename-label { display:block; font-size:12px; color:var(--text-secondary); margin-bottom:6px; }
.vs-rename-input { width:100%; box-sizing:border-box; padding:10px 12px; border-radius:6px;
    border:1px solid var(--border-color); background:var(--bg-tertiary); color:var(--text-primary);
    font-size:14px; font-family:inherit; }
.vs-rename-input:focus { outline:none; border-color:var(--accent-color); }
.vs-rename-hint { font-size:11px; color:var(--text-secondary); margin:8px 0 0; }
.vs-rename-footer { display:flex; gap:8px; justify-content:flex-end; padding:12px 20px;
    border-top:1px solid var(--border-color); }

/* ── Video Station: TMDb search dialog ─────────────────────────── */
.vs-tmdb-overlay { position:fixed; inset:0; background:rgba(0,0,0,.7); z-index:9999;
    display:flex; align-items:center; justify-content:center; }
.vs-tmdb-dialog { background:var(--bg-secondary); border-radius:12px; width:560px;
    max-width:94vw; max-height:85vh; display:flex; flex-direction:column;
    overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.vs-tmdb-header { display:flex; justify-content:space-between; align-items:center;
    padding:16px 20px; border-bottom:1px solid var(--border-color); font-weight:600; font-size:15px;
    flex-shrink:0; }
.vs-tmdb-close { background:none; border:none; color:var(--text-secondary); cursor:pointer;
    font-size:16px; padding:4px; }
.vs-tmdb-close:hover { color:var(--text-primary); }
.vs-tmdb-search-row { display:flex; gap:8px; padding:14px 20px; flex-shrink:0;
    border-bottom:1px solid var(--border-color); }
.vs-tmdb-search-input { flex:1; padding:9px 12px; border-radius:6px;
    border:1px solid var(--border-color); background:var(--bg-tertiary); color:var(--text-primary);
    font-size:14px; font-family:inherit; }
.vs-tmdb-search-input:focus { outline:none; border-color:var(--accent-color); }
.vs-tmdb-search-btn { white-space:nowrap; }
.vs-tmdb-results { overflow-y:auto; flex:1; padding:8px 12px; }
.vs-tmdb-hint { text-align:center; color:var(--text-secondary); font-size:13px; padding:20px; }
.vs-tmdb-error { color:#e74c3c; }
.vs-tmdb-result { display:flex; gap:12px; padding:10px 8px; border-radius:8px; cursor:pointer;
    transition:background .15s; }
.vs-tmdb-result:hover { background:var(--bg-hover); }
.vs-tmdb-poster { width:46px; height:69px; border-radius:4px; object-fit:cover; flex-shrink:0; }
.vs-tmdb-no-poster { background:var(--bg-tertiary); display:flex; align-items:center;
    justify-content:center; color:var(--text-secondary); font-size:18px; }
.vs-tmdb-result-info { flex:1; min-width:0; }
.vs-tmdb-result-title { font-weight:600; font-size:14px; display:flex; align-items:center;
    gap:6px; flex-wrap:wrap; margin-bottom:2px; }
.vs-tmdb-result-year { font-size:12px; color:var(--text-secondary); margin-bottom:4px; }
.vs-tmdb-result-overview { font-size:12px; color:var(--text-secondary); line-height:1.4;
    overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; }
.vs-tmdb-type-badge { font-size:10px; font-weight:700; padding:2px 6px; border-radius:4px;
    text-transform:uppercase; letter-spacing:.5px; flex-shrink:0; }
.vs-tmdb-movie { background:#e67e22; color:#fff; }
.vs-tmdb-tv { background:#3498db; color:#fff; }

/* ── Video Station: Netflix Home ───────────────────────────────── */
.vs-home { display:flex; flex-direction:column; gap:0; padding-bottom:40px; }

/* Hero */
.vs-hero { position:relative; min-height:380px; display:flex; align-items:flex-end;
    overflow:hidden; cursor:pointer; border-radius:0; flex-shrink:0; }
.vs-hero-backdrop { position:absolute; inset:0; background-size:cover; background-position:center top;
    transition:transform .4s; }
.vs-hero:hover .vs-hero-backdrop { transform:scale(1.02); }
.vs-hero-grad { position:absolute; inset:0;
    background:linear-gradient(to top, rgba(8,8,8,1) 0%, rgba(8,8,8,.7) 40%, rgba(8,8,8,.1) 100%); }
.vs-hero-info { position:relative; z-index:1; padding:32px 40px; max-width:600px; }
.vs-hero-rating { font-size:13px; color:#f5c518; font-weight:700; margin-bottom:8px; display:flex; align-items:center; gap:4px; }
.vs-hero-title { font-size:clamp(22px,3vw,40px); font-weight:800; color:#fff; margin:0 0 6px;
    line-height:1.15; text-shadow:0 2px 8px rgba(0,0,0,.6); }
.vs-hero-year { font-size:13px; color:rgba(255,255,255,.6); margin-right:10px; }
.vs-hero-overview { font-size:14px; color:rgba(255,255,255,.8); margin:10px 0 16px;
    line-height:1.5; text-shadow:0 1px 4px rgba(0,0,0,.5); }
.vs-hero-btns { display:flex; gap:10px; flex-wrap:wrap; }
.vs-hero-play { background:var(--accent-color); color:#fff; border:none; padding:11px 24px;
    border-radius:6px; font-size:15px; font-weight:700; cursor:pointer; display:flex;
    align-items:center; gap:8px; transition:filter .15s; }
.vs-hero-play:hover { filter:brightness(1.2); }
.vs-hero-info-btn { background:rgba(255,255,255,.15); color:#fff; border:1px solid rgba(255,255,255,.3);
    padding:10px 20px; border-radius:6px; font-size:14px; cursor:pointer;
    display:flex; align-items:center; gap:7px; backdrop-filter:blur(4px); transition:background .15s; }
.vs-hero-info-btn:hover { background:rgba(255,255,255,.25); }

/* Rows */
.vs-row { padding:20px 0 8px; }
.vs-row-header { display:flex; align-items:center; justify-content:space-between;
    padding:0 20px 10px; }
.vs-row-title { font-size:16px; font-weight:700; color:var(--text-primary); margin:0; }
.vs-row-arrows { display:flex; gap:4px; }
.vs-row-prev, .vs-row-next { background:var(--bg-tertiary); border:none; color:var(--text-secondary);
    width:28px; height:28px; border-radius:50%; cursor:pointer; display:flex;
    align-items:center; justify-content:center; font-size:11px; transition:all .15s; }
.vs-row-prev:hover, .vs-row-next:hover { background:var(--bg-hover); color:var(--text-primary); }
.vs-row-track { display:flex; gap:12px; overflow-x:auto; padding:4px 20px 12px;
    scroll-snap-type:x mandatory; scrollbar-width:none; -ms-overflow-style:none; }
.vs-row-track::-webkit-scrollbar { display:none; }

/* Row cards */
.vs-row-card { flex:0 0 160px; cursor:pointer; transition:transform .2s;
    scroll-snap-align:start; }
.vs-row-card:hover { transform:scale(1.06); z-index:2; }
.vs-row-card-img { position:relative; aspect-ratio:2/3; border-radius:8px; overflow:hidden;
    background:var(--bg-tertiary); }
.vs-row-card-img img { width:100%; height:100%; object-fit:cover; display:block; }
.vs-row-card-noimg { width:100%; height:100%; display:flex; align-items:center;
    justify-content:center; color:var(--text-secondary); font-size:32px; }
.vs-row-progress { position:absolute; bottom:0; left:0; right:0; height:3px;
    background:rgba(255,255,255,.2); }
.vs-row-progress div { height:100%; background:var(--accent-color); }
.vs-row-card-title { font-size:12px; color:var(--text-secondary); margin-top:6px;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding:0 2px; }
.vs-row-card:hover .vs-row-card-title { color:var(--text-primary); }

/* Hover overlay on cards */
.vs-row-card-hover { position:absolute; inset:0; background:rgba(0,0,0,.75);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    gap:8px; opacity:0; transition:opacity .2s; padding:10px; }
.vs-row-card:hover .vs-row-card-hover { opacity:1; }
.vs-row-play-btn { background:rgba(255,255,255,.9); color:#000; border:none;
    width:44px; height:44px; border-radius:50%; font-size:15px; cursor:pointer;
    display:flex; align-items:center; justify-content:center; transition:transform .15s; }
.vs-row-play-btn:hover { transform:scale(1.1); }
.vs-row-hover-rating { font-size:11px; color:#f5c518; font-weight:700; display:flex;
    align-items:center; gap:3px; }
.vs-row-hover-overview { font-size:10px; color:rgba(255,255,255,.85); line-height:1.4;
    text-align:center; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical;
    overflow:hidden; }

/* ── VS Sidebar nav (new layout) ──────────────────────────────────── */
.vs-layout { display:flex; height:100%; overflow:hidden; transition:none; }
.vs-sidebar-header { display:flex; align-items:center; justify-content:space-between;
    padding:12px 14px 10px; border-bottom:1px solid var(--border-color); flex-shrink:0; }
.vs-sidebar-logo { font-size:13px; font-weight:700; color:var(--text-primary);
    display:flex; align-items:center; gap:8px; overflow:hidden; }
.vs-sidebar-logo i { color:var(--accent-color); font-size:16px; flex-shrink:0; }
.vs-sidebar-logo span { white-space:nowrap; transition:opacity .2s; }
.vs-hamburger { background:none; border:none; color:var(--text-secondary); cursor:pointer;
    font-size:16px; padding:4px; border-radius:4px; flex-shrink:0; }
.vs-hamburger:hover { color:var(--text-primary); background:var(--bg-hover); }
.vs-nav-section { padding:10px 14px 4px; font-size:10px; font-weight:700;
    text-transform:uppercase; letter-spacing:.6px; color:var(--text-secondary);
    white-space:nowrap; overflow:hidden; transition:opacity .2s; }
.vs-nav-item { padding:8px 14px; cursor:pointer; display:flex; align-items:center;
    gap:10px; font-size:13px; color:var(--text-secondary); border-radius:6px;
    margin:1px 6px; transition:background .15s, color .15s; white-space:nowrap; }
.vs-nav-item i { width:16px; text-align:center; flex-shrink:0; }
.vs-nav-item span { overflow:hidden; text-overflow:ellipsis; transition:opacity .2s; }
.vs-nav-item:hover { background:var(--bg-hover); color:var(--text-primary); }
.vs-nav-item.active { background:var(--accent-color); color:#fff; }
.vs-nav-badge { background:var(--accent-color); color:#fff; font-size:10px;
    border-radius:99px; padding:1px 6px; margin-left:auto; }
.vs-sidebar-stats { padding:12px 14px; font-size:11px; color:var(--text-secondary);
    border-top:1px solid var(--border-color); margin-top:auto; overflow:hidden; }

/* Collapsed sidebar */
.vs-layout.vs-sidebar-collapsed .vs-sidebar { width:52px; min-width:52px; }
.vs-layout.vs-sidebar-collapsed .vs-sidebar-logo span,
.vs-layout.vs-sidebar-collapsed .vs-nav-section,
.vs-layout.vs-sidebar-collapsed .vs-nav-item span,
.vs-layout.vs-sidebar-collapsed .vs-nav-badge,
.vs-layout.vs-sidebar-collapsed .vs-sidebar-stats { opacity:0; pointer-events:none; width:0; overflow:hidden; }
.vs-layout.vs-sidebar-collapsed .vs-nav-item { justify-content:center; padding:8px 0; margin:1px 4px; }
.vs-layout.vs-sidebar-collapsed .vs-sidebar-header { padding:12px 8px 10px; }
.vs-toolbar-title { font-size:15px; font-weight:700; color:var(--text-primary);
    display:flex; align-items:center; gap:8px; }

/* ── VS Settings page ─────────────────────────────────────────────── */
.vs-settings-page { padding:24px; display:flex; flex-direction:column; gap:20px;
    max-width:700px; overflow-y:auto; }
.vs-settings-card { background:var(--bg-secondary); border:1px solid var(--border-color);
    border-radius:10px; padding:20px; }
.vs-settings-card-title { font-size:14px; font-weight:700; color:var(--text-primary);
    margin-bottom:12px; display:flex; align-items:center; gap:8px; }
.vs-settings-desc { font-size:12px; color:var(--text-secondary); margin:0 0 12px; line-height:1.5; }
.vs-settings-row { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.vs-settings-actions { display:flex; gap:10px; flex-wrap:wrap; }
.vs-tmdb-key-row { display:flex; gap:8px; align-items:center; }
.vs-input { padding:7px 10px; border:1px solid var(--border-color); border-radius:6px;
    background:var(--bg-primary); color:var(--text-primary); font-size:13px; flex:1; }
.vs-input:focus { outline:none; border-color:var(--accent-color); }
.vs-hw-badge { display:inline-flex; align-items:center; gap:6px; padding:6px 12px;
    border-radius:20px; font-size:12px; font-weight:600; margin-bottom:8px; }
.vs-hw-badge-hw { background:rgba(250,204,21,.15); color:#facc15; border:1px solid rgba(250,204,21,.3); }
.vs-hw-badge-sw { background:rgba(148,163,184,.1); color:var(--text-secondary);
    border:1px solid var(--border-color); }

/* ── VS Player extras ─────────────────────────────────────────────── */
.vs-stats-btn { background:none; border:none; color:rgba(255,255,255,.7); cursor:pointer;
    font-size:14px; padding:4px 6px; border-radius:4px; }
.vs-stats-btn:hover { color:#fff; background:rgba(255,255,255,.1); }
.vs-stats-overlay { position:absolute; top:56px; right:12px; background:rgba(0,0,0,.82);
    border:1px solid rgba(255,255,255,.15); border-radius:8px; padding:12px 16px;
    font-size:12px; color:#fff; z-index:10; min-width:200px; backdrop-filter:blur(4px); }
.vs-stats-row { display:flex; justify-content:space-between; gap:24px; padding:3px 0;
    border-bottom:1px solid rgba(255,255,255,.07); }
.vs-stats-row:last-child { border-bottom:none; }
.vs-seek-hint { position:absolute; top:50%; transform:translateY(-50%); display:flex;
    flex-direction:column; align-items:center; gap:4px; font-size:13px; color:#fff;
    background:rgba(0,0,0,.55); border-radius:50%; width:72px; height:72px;
    justify-content:center; pointer-events:none; opacity:0; transition:opacity .2s; z-index:8; }
.vs-seek-hint-left { left:10%; }
.vs-seek-hint-right { right:10%; }
.vs-seek-hint.vs-seek-hint-visible { opacity:1; }
.vs-swipe-hint { position:absolute; bottom:72px; left:50%; transform:translateX(-50%);
    background:rgba(0,0,0,.7); color:#fff; padding:6px 14px; border-radius:20px;
    font-size:13px; pointer-events:none; display:none; z-index:8; }

/* ── VS Custom Player Controls ──────────────────────────────────── */
/* Center controls (play/pause, ±10s) */
.vs-player-center { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    display:flex; align-items:center; gap:48px; z-index:6;
    opacity:1; transition:opacity .25s; pointer-events:auto; }
.vs-player-overlay.vs-ctrl-hidden .vs-player-center { opacity:0; pointer-events:none; }
.vs-cc-btn { background:rgba(0,0,0,.45); border:none; color:#fff; width:56px; height:56px;
    border-radius:50%; cursor:pointer; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:1px; font-size:20px;
    backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
    transition:background .15s, transform .1s; touch-action:manipulation; }
.vs-cc-btn:active { transform:scale(.9); background:rgba(255,255,255,.18); }
.vs-cc-btn span { font-size:11px; font-weight:700; line-height:1; }
.vs-cc-play { width:72px; height:72px; font-size:28px; }
.vs-cc-play:active { transform:scale(.88); }

/* Bottom bar (seekbar + time) */
.vs-player-bottom { position:absolute; bottom:0; left:0; right:0; z-index:6;
    display:flex; align-items:center; gap:10px; padding:0 16px 14px;
    background:linear-gradient(to top,rgba(0,0,0,.82) 0%,rgba(0,0,0,.4) 60%,transparent 100%);
    opacity:1; transition:opacity .25s; pointer-events:auto; }
.vs-player-overlay.vs-ctrl-hidden .vs-player-bottom { opacity:0; pointer-events:none; }
.vs-player-overlay.vs-ctrl-hidden .vs-player-top { opacity:0; pointer-events:none; }
.vs-player-top { transition:opacity .25s; }
.vs-pb-time { color:#fff; font-size:12px; font-variant-numeric:tabular-nums;
    white-space:nowrap; min-width:42px; text-align:center; user-select:none; }

/* Seekbar */
.vs-pb-seek-wrap { flex:1; position:relative; height:28px; display:flex;
    align-items:center; cursor:pointer; touch-action:none; }
.vs-pb-seek-track { position:absolute; left:0; right:0; height:4px;
    background:rgba(255,255,255,.25); border-radius:2px; overflow:hidden;
    pointer-events:none; transition:height .15s; }
.vs-pb-seek-wrap:hover .vs-pb-seek-track,
.vs-pb-seek-wrap:active .vs-pb-seek-track { height:6px; }
.vs-pb-seek-buf { position:absolute; height:100%; background:rgba(255,255,255,.25);
    border-radius:2px; width:0; }
.vs-pb-seek-fill { position:absolute; height:100%; background:var(--accent,#4f8cff);
    border-radius:2px; width:0; }
.vs-pb-seek { position:absolute; left:0; right:0; width:100%; height:28px;
    opacity:0; cursor:pointer; margin:0; -webkit-appearance:none; appearance:none;
    touch-action:none; }
.vs-pb-seek::-webkit-slider-thumb { -webkit-appearance:none; width:16px; height:16px;
    background:#fff; border-radius:50%; cursor:pointer; }
.vs-pb-seek::-moz-range-thumb { width:16px; height:16px; background:#fff;
    border-radius:50%; cursor:pointer; border:none; }

/* Folder rescan rows in settings */
.vs-folder-rescan-row { display:flex; align-items:center; gap:10px; padding:8px 0;
    border-bottom:1px solid var(--border-color); }
.vs-folder-rescan-row:last-child { border-bottom:none; }
.vs-folder-rescan-path { flex:1; font-size:12px; color:var(--text-secondary);
    font-family:monospace; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ── VS HW Health Banner ──────────────────────────────────────────── */
.vs-hw-banner { display:flex; align-items:center; gap:10px; padding:10px 16px;
    background:rgba(250,176,5,.12); border-bottom:1px solid rgba(250,176,5,.3);
    color:#fbbf24; font-size:13px; flex-shrink:0; }
.vs-hw-banner i.fa-exclamation-triangle, .vs-hw-banner i.fa-lock { font-size:16px; flex-shrink:0; }
.vs-hw-banner-error { background:rgba(239,68,68,.12); border-bottom-color:rgba(239,68,68,.35);
    color:#fca5a5; }
.vs-hw-banner-error .vs-hw-banner-btn { background:rgba(239,68,68,.2);
    border-color:rgba(239,68,68,.4); color:#fca5a5; }
.vs-hw-banner-error .vs-hw-banner-btn:hover { background:rgba(239,68,68,.35); }
.vs-hw-banner-error .vs-hw-banner-close { color:rgba(239,68,68,.6); }
.vs-hw-banner-error .vs-hw-banner-close:hover { color:#fca5a5; }
.vs-hw-banner-msg { flex:1; line-height:1.4; }
.vs-hw-banner-btn { background:rgba(250,176,5,.2); border:1px solid rgba(250,176,5,.4);
    color:#fbbf24; border-radius:6px; padding:5px 12px; font-size:12px; cursor:pointer;
    white-space:nowrap; transition:background .15s; }
.vs-hw-banner-btn:hover { background:rgba(250,176,5,.35); }
.vs-hw-banner-close { background:none; border:none; color:rgba(250,176,5,.6);
    cursor:pointer; font-size:14px; padding:2px 6px; margin-left:4px; }
.vs-hw-banner-close:hover { color:#fbbf24; }

/* ── VS HW Setup Wizard Modal ─────────────────────────────────────── */
.vs-hw-modal { position:absolute; inset:0; z-index:200; display:flex;
    align-items:center; justify-content:center; }
.vs-hw-modal-backdrop { position:absolute; inset:0; background:rgba(0,0,0,.65);
    backdrop-filter:blur(4px); }
.vs-hw-modal-box { position:relative; width:min(600px,92%); max-height:80vh;
    background:#161b22; border:1px solid rgba(255,255,255,.1); border-radius:12px;
    display:flex; flex-direction:column; overflow:hidden;
    box-shadow:0 24px 64px rgba(0,0,0,.7); }
.vs-hw-modal-header { display:flex; align-items:center; gap:10px; padding:16px 20px;
    border-bottom:1px solid rgba(255,255,255,.08); font-size:15px; font-weight:600;
    color:#fff; flex-shrink:0; }
.vs-hw-modal-header i { color:#facc15; font-size:18px; }
.vs-hw-modal-header span { flex:1; }
.vs-hw-modal-close { background:none; border:none; color:rgba(255,255,255,.5);
    cursor:pointer; font-size:16px; padding:4px 8px; }
.vs-hw-modal-close:hover { color:#fff; }
.vs-hw-modal-body { flex:1; overflow-y:auto; padding:20px; display:flex;
    flex-direction:column; gap:16px; }
.vs-hw-modal-status { padding:10px 14px; border-radius:8px; font-size:13px;
    line-height:1.5; display:flex; align-items:flex-start; gap:8px; }
.vs-hw-status-missing_driver { background:rgba(239,68,68,.1); color:#fca5a5;
    border:1px solid rgba(239,68,68,.25); }
.vs-hw-status-permission_denied { background:rgba(239,68,68,.1); color:#fca5a5;
    border:1px solid rgba(239,68,68,.25); }
.vs-hw-status-no_render_node { background:rgba(99,102,241,.1); color:#a5b4fc;
    border:1px solid rgba(99,102,241,.25); }
.vs-hw-status-cpu_only { background:rgba(148,163,184,.08); color:var(--text-secondary);
    border:1px solid var(--border-color); }
.vs-hw-modal-cpu { font-size:12px; color:var(--text-secondary);
    font-family:monospace; padding:4px 0; }
.vs-hw-modal-diag { display:flex; flex-direction:column; gap:4px; padding:12px 14px;
    background:rgba(255,255,255,.03); border-radius:8px; border:1px solid rgba(255,255,255,.07); }
.vs-hw-diag-row { display:flex; justify-content:space-between; align-items:center;
    font-size:12px; padding:4px 0; border-bottom:1px solid rgba(255,255,255,.05); }
.vs-hw-diag-row:last-child { border-bottom:none; }
.vs-hw-diag-ok { color:#4ade80; display:flex; align-items:center; gap:4px; }
.vs-hw-diag-fail { color:#f87171; display:flex; align-items:center; gap:4px; }
.vs-hw-modal-steps { display:flex; flex-direction:column; gap:12px; }
.vs-hw-step { background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.07);
    border-radius:8px; overflow:hidden; }
.vs-hw-step-title { padding:10px 14px; font-size:13px; font-weight:600; color:#e2e8f0;
    background:rgba(255,255,255,.04); border-bottom:1px solid rgba(255,255,255,.06); }
.vs-hw-cmd { display:flex; align-items:center; gap:8px; padding:8px 14px;
    border-bottom:1px solid rgba(255,255,255,.04); }
.vs-hw-cmd:last-child { border-bottom:none; }
.vs-hw-cmd code { flex:1; font-family:monospace; font-size:12px; color:#93c5fd;
    word-break:break-all; line-height:1.5; }
.vs-hw-cmd-copy { background:none; border:1px solid rgba(255,255,255,.12);
    color:rgba(255,255,255,.5); border-radius:5px; padding:3px 8px; cursor:pointer;
    font-size:11px; flex-shrink:0; transition:all .15s; }
.vs-hw-cmd-copy:hover { background:rgba(255,255,255,.1); color:#fff; }
.vs-hw-modal-footer { display:flex; gap:10px; justify-content:flex-end; padding:14px 20px;
    border-top:1px solid rgba(255,255,255,.08); flex-shrink:0; }

/* Stats overlay HW tip */
.vs-stats-hw-tip { margin-top:8px; padding:8px 10px; background:rgba(250,176,5,.1);
    border:1px solid rgba(250,176,5,.25); border-radius:6px; font-size:11px;
    color:#fcd34d; line-height:1.5; }
.vs-stats-hw-link { color:#fbbf24; text-decoration:underline; cursor:pointer; }
.vs-stats-hw-link:hover { color:#fff; }
.vs-hw-install-log {
    background:#0d1117; color:#c9d1d9; font-size:11px; line-height:1.5;
    padding:10px 12px; margin:0; max-height:180px; overflow-y:auto;
    border-top:1px solid #333; border-radius:0 0 8px 8px; white-space:pre-wrap;
    word-break:break-all;
}
.vs-hw-docker-warn { display:flex; align-items:flex-start; gap:8px; padding:10px 14px;
    background:rgba(56,189,248,.08); border:1px solid rgba(56,189,248,.25);
    border-radius:8px; font-size:12px; color:#7dd3fc; line-height:1.5; }
.vs-hw-docker-warn i { font-size:16px; flex-shrink:0; margin-top:1px; }
.vs-hw-docker-warn code { background:rgba(56,189,248,.12); padding:1px 5px;
    border-radius:4px; font-family:monospace; font-size:11px; }
.vs-hw-vainfo-result { padding:10px 14px; border-radius:8px; font-size:12px; line-height:1.5; }
.vs-hw-vainfo-ok { background:rgba(74,222,128,.08); border:1px solid rgba(74,222,128,.25);
    color:#4ade80; }
.vs-hw-vainfo-fail { background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.25);
    color:#fca5a5; }
.vs-hw-vainfo-profiles { margin:6px 0 0 0; padding-left:18px; color:#86efac; font-size:11px; }
.vs-hw-vainfo-err { margin-top:4px; font-family:monospace; font-size:11px;
    color:#fca5a5; opacity:.85; }
/* Green "confirmed active" HW badge — shown after vainfo or auto-install succeeds */
.vs-hw-badge-active { background:rgba(74,222,128,.15); color:#4ade80;
    border:1px solid rgba(74,222,128,.3); }

/* iHD init-failed alert block */
.vs-hw-ihd-alert { background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.4);
    border-radius:8px; padding:12px 14px; margin-bottom:12px; }
.vs-hw-ihd-alert-header { display:flex; align-items:center; gap:8px; margin-bottom:8px;
    color:#f87171; font-size:14px; }
.vs-hw-ihd-alert-header i { flex-shrink:0; font-size:16px; }
.vs-hw-ihd-alert-body { display:flex; flex-direction:column; gap:4px; }
.vs-hw-ihd-row { display:flex; justify-content:space-between; align-items:center;
    font-size:12px; gap:8px; }
.vs-hw-ihd-label { color:var(--text-secondary); flex-shrink:0; }
.vs-hw-ihd-val { font-weight:600; }
.vs-hw-ihd-val.ok  { color:#4ade80; }
.vs-hw-ihd-val.warn { color:#facc15; }
.vs-hw-ihd-val.fail { color:#f87171; }

/* Codec pills in settings encoder card */
.vs-codec-pills { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.vs-codec-pill { display:inline-flex; align-items:center; gap:5px; padding:3px 10px;
    border-radius:20px; font-size:11px; font-weight:600; cursor:default; }
.vs-codec-pill-ok   { background:rgba(74,222,128,.15); color:#4ade80; border:1px solid rgba(74,222,128,.3); }
.vs-codec-pill-fail { background:rgba(239,68,68,.1); color:#f87171; border:1px solid rgba(239,68,68,.3); }


