:root{--bg-primary: #ffffff;--bg-secondary: #f0f0f0;--bg-sidebar: #f5f5f5;--bg-hover: #e8e8e8;--bg-selected: #d3e5ff;--bg-selected-unfocused: #d9d9d9;--bg-row-alt: #fafafa;--border-color: #d1d1d1;--text-primary: #1a1a1a;--text-secondary: #666666;--text-muted: #999999;--accent-color: #1a73e8;--danger-color: #d32f2f;--success-color: #2e7d32;--toolbar-bg: #f8f9fa;--breadcrumb-bg: #ffffff;--breadcrumb-border: #e0e0e0;--scrollbar-thumb: #c1c1c1;--shadow-light: 0 1px 3px rgba(0,0,0,.1);--font-family: "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--font-size-sm: 12px;--font-size-base: 13px;--font-size-lg: 14px;--row-border: #f0f0f0;--input-bg: #ffffff;--banner-bg: #fff3cd;--banner-border: #ffc107;--banner-text: #856404;--audit-banner-bg: #e3f2fd;--audit-banner-border: #90caf9;--audit-banner-text: #1565c0;--pagination-bg: #ffffff;--pagination-border: #e0e0e0;--restore-btn-bg: #ffffff;--tree-line-color: #d1d1d1}[data-theme=dark]{--bg-primary: #1e1e1e;--bg-secondary: #2d2d2d;--bg-sidebar: #252526;--bg-hover: #2a2d2e;--bg-selected: #1a4d7a;--bg-selected-unfocused: #37373d;--bg-row-alt: #232323;--border-color: #3c3c3c;--text-primary: #cccccc;--text-secondary: #9d9d9d;--text-muted: #6d6d6d;--accent-color: #4da3ff;--danger-color: #f44747;--success-color: #4ec9b0;--toolbar-bg: #2d2d2d;--breadcrumb-bg: #1e1e1e;--breadcrumb-border: #3c3c3c;--scrollbar-thumb: #4a4a4a;--shadow-light: 0 1px 3px rgba(0,0,0,.4);--row-border: #2d2d2d;--input-bg: #3c3c3c;--banner-bg: #3e3218;--banner-border: #6e5c1e;--banner-text: #d4a94e;--audit-banner-bg: #1a2a3e;--audit-banner-border: #2a4a6e;--audit-banner-text: #6cb6ff;--pagination-bg: #2d2d2d;--pagination-border: #3c3c3c;--restore-btn-bg: #2d2d2d;--tree-line-color: #4a4a4a}*{box-sizing:border-box;margin:0;padding:0}button{color:var(--text-primary)}:focus:not(:focus-visible){outline:none}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px;border-radius:2px}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:var(--bg-primary);overflow:hidden;height:100vh}#root{height:100vh;display:flex;flex-direction:column}.app-shell{display:flex;flex-direction:column;height:100vh}.app-toolbar{display:flex;align-items:center;gap:2px;padding:3px 8px;background:var(--toolbar-bg);border-bottom:1px solid var(--border-color);min-height:40px}.app-toolbar .toolbar-title{font-weight:700;font-size:15px;margin-right:8px;color:var(--accent-color);letter-spacing:-.3px;padding:0 8px;flex-shrink:0}.toolbar-separator{width:1px;height:28px;background:var(--border-color);margin:0 4px;flex-shrink:0}.toolbar-spacer{flex:1}.toolbar-search{display:flex;align-items:center;gap:4px;padding:3px 8px;background:var(--input-bg, #fff);border:1px solid var(--border-color);border-radius:4px;min-width:0;max-width:200px}.toolbar-search svg{flex-shrink:0;color:var(--text-muted)}.toolbar-search-input{border:none;outline:none;background:transparent;font-size:12px;color:var(--text-primary);width:100%;min-width:60px;padding:0}.toolbar-search-input::placeholder{color:var(--text-muted)}.toolbar-search-clear{background:none;border:none;cursor:pointer;font-size:14px;color:var(--text-muted);padding:0 2px;line-height:1}.toolbar-filter-select{padding:3px 6px;font-size:11px;background:var(--input-bg, #fff);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;outline:none}.toolbar-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:4px 10px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text-primary);cursor:pointer;font-family:var(--font-family);min-width:48px;height:42px;transition:background .1s ease,transform .1s ease;position:relative}.toolbar-btn:hover{background:var(--bg-hover);border-color:var(--border-color)}.toolbar-btn:active{background:var(--bg-selected);transform:scale(.96)}.toolbar-btn .btn-icon{font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;height:18px}.toolbar-btn .btn-icon svg{width:16px;height:16px}.toolbar-btn .btn-label{font-size:10px;line-height:1;color:var(--text-secondary);white-space:nowrap}.toolbar-btn.primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.toolbar-btn.primary:hover{background:#106ebe}.toolbar-btn.primary .btn-label{color:#ffffffd9}.toolbar-btn.danger .btn-icon,.toolbar-btn.danger .btn-label{color:var(--danger-color)}.toolbar-btn-sync{min-width:90px;justify-content:center}.toolbar-btn-pull{border-color:#388e3c;background:#388e3c1a}.toolbar-btn-pull .btn-icon,.toolbar-btn-pull .btn-label{color:#4caf50}.toolbar-btn-pull:hover{background:#388e3c38;border-color:#2e7d32}.toolbar-btn-push{border-color:#1565c0;background:#1565c014}.toolbar-btn-push .btn-icon,.toolbar-btn-push .btn-label{color:#1e88e5}.toolbar-btn-push:hover{background:#1565c02e;border-color:#0d47a1}.toolbar-btn-push:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn-push:disabled:hover{background:#1565c014;border-color:#1565c0}.toolbar-btn-push.toolbar-btn-loading{opacity:.85;cursor:wait;border-color:#1565c0}.toolbar-btn-push.toolbar-btn-loading .btn-icon,.toolbar-btn-push.toolbar-btn-loading .btn-label{color:#64b5f6}.toolbar-btn-fetch:hover{background:var(--bg-hover)}.toolbar-btn-fetch.toolbar-btn-loading,.toolbar-btn-loading{opacity:.85;cursor:wait}.toolbar-btn-sync.toolbar-btn-loading{flex-wrap:wrap;padding-bottom:2px}.toolbar-progress-bar{width:100%;height:3px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:1px}.toolbar-progress-fill{height:100%;border-radius:2px;transition:width .3s ease}.toolbar-btn-push .toolbar-progress-fill{background:#42a5f5}.toolbar-btn-fetch .toolbar-progress-fill{background:#90caf9}@keyframes toolbar-progress-indeterminate{0%{transform:translate(-100%)}to{transform:translate(200%)}}.toolbar-progress-indeterminate{width:40%;animation:toolbar-progress-indeterminate 1.2s ease-in-out infinite}@keyframes toolbar-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.toolbar-spin{animation:toolbar-spin .8s linear infinite}.toolbar-sync-status{font-size:10px;padding:2px 8px;border-radius:4px;white-space:nowrap;animation:toolbar-sync-fadein .3s ease}.toolbar-sync-ok{color:#4caf50;background:#388e3c1a;border:1px solid rgba(56,142,60,.25)}@keyframes toolbar-sync-fadein{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}.toolbar-user{font-size:11px;color:var(--text-secondary);padding:0 6px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lang-switcher{position:relative}.lang-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 12px #00000026;min-width:160px;z-index:1000;padding:4px 0}.lang-option{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .1s ease}.lang-option:hover{background:var(--bg-hover)}.lang-option.active{background:var(--bg-selected);font-weight:600}.lang-option .lang-flag{font-size:16px;flex-shrink:0}.app-body{display:flex;flex:1;overflow:hidden}.projects-panel{min-width:100px;flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.projects-panel-header{padding:8px 12px;font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);border-bottom:1px solid var(--border-color);flex-shrink:0}.projects-panel-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:4px 0}.projects-panel-item{display:flex;align-items:center;gap:6px;padding:6px 12px;cursor:pointer;font-size:var(--font-size-base);color:var(--text-primary);border-left:3px solid transparent;transition:background .1s,transform .1s ease}.projects-panel-item:hover{background:var(--bg-hover)}.projects-panel-item:active{transform:scale(.98)}.projects-panel-item.active{background:var(--bg-selected);border-left-color:var(--accent-color);font-weight:600}.projects-panel-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.projects-panel-star{color:#f5a623;font-size:14px;flex-shrink:0}.projects-panel-badge{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 4px;border-radius:8px;font-size:10px;font-weight:600;line-height:1;white-space:nowrap}.projects-panel-badge.push{background:#ff950026;color:#e68a00}.projects-panel-badge.pull{background:#0a84ff26;color:#0a84ff}[data-theme=dark] .projects-panel-badge.push{background:#ff9f0a33;color:#ff9f0a}[data-theme=dark] .projects-panel-badge.pull{background:#0a84ff33;color:#64b5f6}.projects-panel-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.projects-panel-dot.push{background:#e68a00}.projects-panel-dot.pull{background:#0a84ff;animation:sync-dot-pulse 2s ease-in-out infinite}[data-theme=dark] .projects-panel-dot.push{background:#ff9f0a}[data-theme=dark] .projects-panel-dot.pull{background:#64b5f6}@keyframes sync-dot-pulse{0%,to{opacity:1}50%{opacity:.4}}.projects-panel-empty{padding:12px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}@media(max-width:768px){.projects-panel{display:none}}.sidebar{width:var(--sidebar-width, 220px);min-width:160px;flex-shrink:0;background:var(--bg-sidebar);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.sidebar-tabs{display:flex;gap:2px;padding:6px 8px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.sidebar-tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:5px 8px;font-size:11px;font-weight:500;cursor:pointer;background:transparent;color:var(--text-muted);border:1px solid transparent;border-radius:4px;transition:background .15s,color .15s,border-color .15s,transform .1s ease;font-family:var(--font-family)}.sidebar-tab-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-tab-btn:active{transform:scale(.96)}.sidebar-tab-btn.active{background:var(--accent-color-alpha, rgba(0, 120, 212, .1));color:var(--accent-color);border-color:var(--accent-color-alpha, rgba(0, 120, 212, .2));font-weight:600}.sidebar-tab-btn svg{flex-shrink:0}.sidebar-scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0}.sidebar-bottom-pinned{flex-shrink:0;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.sidebar-bottom-nav{padding:4px 0}.sidebar-bottom-nav .sidebar-item{padding:5px 14px;font-size:12px;border-left:none;color:var(--text-secondary)}.sidebar-bottom-nav .sidebar-item:hover{color:var(--text-primary)}.sidebar-account-section{border-top:1px solid var(--border-color);padding:6px 10px;display:flex;flex-direction:column;gap:4px}.sidebar-account-row{display:flex;align-items:center;gap:4px;min-height:28px}.sidebar-account-row-spacer{flex:1}.sidebar-action-buttons{display:flex;align-items:center;gap:3px;flex-shrink:0}.sidebar-account-user{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--text-primary);overflow:hidden;min-width:0}.sidebar-account-user svg{flex-shrink:0;opacity:.5}.sidebar-account-user span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-storage-badge{font-size:9px;font-weight:600;color:var(--text-muted);background:var(--bg-hover, rgba(0,0,0,.06));padding:1px 5px;border-radius:3px;flex-shrink:0;white-space:nowrap}.sidebar-version-btn{font-size:10px;color:var(--text-muted);font-weight:500;background:transparent;border:1px solid transparent;border-radius:4px;padding:2px 8px;cursor:pointer;font-family:var(--font-family);transition:background .15s,color .15s,border-color .15s;white-space:nowrap}.sidebar-version-btn:hover{background:var(--bg-hover);color:var(--text-secondary);border-color:var(--border-color)}.sidebar-version-btn-update{color:var(--accent-color, #1a73e8);background:#1a73e814;border-color:#1a73e840;font-weight:600}.sidebar-version-btn-update:hover{background:#1a73e826;border-color:var(--accent-color, #1a73e8)}.sidebar-version-btn:disabled{cursor:default;opacity:.7}.sidebar-notif-bell{display:inline-flex}.sidebar-notif-bell .notification-bell{margin-right:0}.sidebar-notif-bell .toolbar-btn{padding:0;min-width:26px;width:26px;height:26px;font-size:11px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:5px}.sidebar-notif-bell .toolbar-btn:hover{background:var(--bg-hover, #e8e8e8);border-color:var(--text-muted)}.sidebar-settings-btn{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;padding:0;font-size:11px;cursor:pointer;background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:5px;transition:background .15s,color .15s,border-color .15s}.sidebar-settings-btn:hover{background:var(--bg-hover, #e8e8e8);color:var(--text-primary);border-color:var(--text-muted)}.sidebar-signout-btn{color:var(--danger-color, #d32f2f);border-color:transparent;background:#d32f2f0f}.sidebar-signout-btn:hover{background:#d32f2f1f;border-color:var(--danger-color, #d32f2f)}.lang-switcher-sidebar{position:relative}.sidebar-resize-handle{width:4px;cursor:col-resize;flex-shrink:0;background:transparent;position:relative;z-index:10;transition:background .15s}.sidebar-resize-handle:hover,.sidebar-resize-handle.dragging{background:var(--accent-color, #0078d4)}.sidebar-section{padding:6px 0}.sidebar-section+.sidebar-section{border-top:1px solid var(--border-color)}.sidebar-section-title{padding:6px 14px 4px;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.sidebar-clone-btn{display:flex;align-items:center;gap:6px;width:100%;padding:6px 10px;font-size:12px;font-weight:500;cursor:pointer;border:1px solid var(--accent-color, #0078d4);border-radius:4px;background:var(--accent-color-alpha, rgba(0, 120, 212, .08));color:var(--accent-color, #0078d4);transition:background .15s,opacity .15s}.sidebar-clone-btn:hover{background:var(--accent-color-alpha, rgba(0, 120, 212, .15))}.sidebar-clone-btn svg{flex-shrink:0}.sidebar-pull-btn{border-color:var(--accent-color, #0078d4);background:var(--accent-color, #0078d4);color:#fff}.sidebar-pull-btn:hover{opacity:.9}.sidebar-cloned-info{padding:6px 0 0}.sidebar-cloned-btn-linked{color:#4caf50;border-color:#4caf504d;background:#4caf500f}.sidebar-cloned-btn-linked:hover{background:#4caf501f;border-color:#4caf5080;color:#4caf50}.sidebar-cloned-path{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:5px;cursor:pointer;transition:background .15s,color .15s;overflow:hidden}.sidebar-cloned-path:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar-cloned-path svg{flex-shrink:0;opacity:.6}.sidebar-cloned-path span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-cloned-actions{display:flex;gap:6px;margin-top:6px}.sidebar-cloned-btn{display:flex;align-items:center;gap:5px;flex:1;justify-content:center;padding:5px 10px;font-size:12px;font-weight:500;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-family:var(--font-family);transition:background .15s,border-color .15s,color .15s}.sidebar-cloned-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.sidebar-cloned-btn svg{flex-shrink:0}.sidebar-cloned-btn-danger{color:var(--danger-color, #c62828);border-color:#c6282840;background:#c628280a}.sidebar-cloned-btn-danger:hover{background:#c628281a;border-color:var(--danger-color, #c62828);color:var(--danger-color, #c62828)}.sidebar-changes-list{max-height:200px;overflow-y:auto;padding-bottom:4px}.sidebar-change-item{display:flex;align-items:center;gap:5px;padding:2px 8px 2px 12px;font-size:12px;min-height:24px}.sidebar-change-item:hover{background:var(--bg-hover, rgba(0,0,0,.04))}.sidebar-change-badge{width:15px;height:15px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.sidebar-change-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.sidebar-change-name.sidebar-change-removed{text-decoration:line-through;opacity:.6}.sidebar-change-push{font-size:10px;padding:1px 6px;border:1px solid var(--border-color);border-radius:3px;background:transparent;color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:background .1s,color .1s}.sidebar-change-push:hover{background:#1565c0;color:#fff;border-color:#1565c0}.sidebar-change-push:disabled{opacity:.4;cursor:not-allowed}.sidebar-item{display:flex;align-items:center;gap:8px;padding:5px 14px 5px 16px;cursor:pointer;font-size:13px;-webkit-user-select:none;user-select:none;border-left:2px solid transparent;transition:background .1s ease,border-color .1s ease;overflow:hidden;color:var(--text-primary)}.sidebar-item>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item:hover{background:var(--bg-hover)}.sidebar-item.active{background:var(--bg-selected);border-left-color:var(--accent-color, #0078d4);font-weight:500}.sidebar-item .sidebar-icon{display:flex;align-items:center;flex-shrink:0;color:var(--text-muted)}.sidebar-item:hover .sidebar-icon,.sidebar-item.active .sidebar-icon{color:var(--text-primary)}.sidebar-item .sidebar-icon svg{width:16px;height:16px}.sidebar-item.sidebar-file-item{font-size:11px;opacity:.8}.sidebar-item.sidebar-file-item:hover{opacity:1}.tree-children-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .2s ease-out;padding-left:8px;margin-left:16px;border-left:1px solid var(--tree-line-color)}.tree-children-wrapper.expanded{grid-template-rows:1fr}.tree-children{min-height:0;overflow:hidden}.tree-toggle{width:16px;height:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--text-secondary);transition:transform .15s ease}.tree-toggle svg{width:10px;height:10px}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.sync-toast{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:6px;font-size:12px;font-weight:500;color:#fff;background:#0a84ffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 2px 12px #0003;cursor:pointer;animation:sync-toast-in .3s ease-out;pointer-events:auto}.sync-toast svg{flex-shrink:0;stroke:#fff}@keyframes sync-toast-in{0%{opacity:0;transform:translate(-50%) translateY(-12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.breadcrumbs{display:flex;align-items:center;gap:0;padding:2px 8px;background:var(--breadcrumb-bg);border-bottom:1px solid var(--breadcrumb-border);font-size:var(--font-size-base);min-height:28px}.breadcrumbs-bar{display:flex;align-items:center;flex:1;background:var(--input-bg);border:1px solid var(--border-color);border-radius:3px;padding:1px 4px;min-height:22px;gap:0}.breadcrumb-item{cursor:pointer;padding:1px 5px;border-radius:3px;color:var(--accent-color);font-size:var(--font-size-base);white-space:nowrap;transition:background .1s ease}.breadcrumb-item:hover{background:var(--bg-hover)}.breadcrumb-item.current{color:var(--text-primary);font-weight:500;cursor:default}.breadcrumb-item.current:hover{background:transparent}.breadcrumb-chevron{color:var(--text-muted);display:flex;align-items:center;flex-shrink:0}.breadcrumb-chevron svg{width:10px;height:10px}.file-list-container{flex:1;overflow-y:auto;overflow-x:auto}.file-list-scroll-inner{width:max-content;min-width:100%}.file-list-header{display:grid;gap:8px;padding:6px 12px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);position:sticky;top:0;z-index:1}.file-list-header .sortable-header{cursor:pointer;display:flex;align-items:center;gap:4px;-webkit-user-select:none;user-select:none;transition:color .1s ease;overflow:hidden;white-space:nowrap;min-width:0}.file-list-header .sortable-header:hover{color:var(--accent-color)}.col-header-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.sort-indicators{display:inline-flex;flex-direction:column;line-height:1;margin-left:2px;flex-shrink:0}.sort-indicators:not(.active){opacity:0;transition:opacity .15s ease}.sortable-header:hover .sort-indicators:not(.active){opacity:1}.sort-arrow{font-size:7px;line-height:.85;opacity:.25}.sort-arrow.current{opacity:1;color:var(--accent-color)}.file-list-row{display:grid;gap:8px;padding:4px 12px;border-bottom:1px solid var(--row-border);cursor:default;-webkit-user-select:none;user-select:none;align-items:center;min-height:26px;transition:background .08s ease}.file-list-row:nth-child(2n){background:var(--bg-row-alt)}.file-list-row:hover{background:var(--bg-hover)}.file-list-row.selected{background:var(--bg-selected);border-left:2px solid var(--accent-color);padding-left:10px}.file-list-row.file-focused,.file-compact-row.file-focused,.file-grid-item.file-focused{outline:1px solid rgba(100,160,255,.5);outline-offset:-1px}.file-list-container:focus{outline:none}.file-list-row.drag-over,.file-compact-row.drag-over,.file-grid-item.drag-over{outline:2px dashed var(--accent-color);outline-offset:-2px;background:var(--accent-color-alpha, rgba(0,120,212,.08))}.file-list-row[draggable=true],.file-compact-row[draggable=true],.file-grid-item[draggable=true]{cursor:grab}.file-list-row[draggable=true]:active,.file-compact-row[draggable=true]:active,.file-grid-item[draggable=true]:active{cursor:grabbing}.file-name-cell{display:flex;align-items:center;gap:6px;overflow:hidden}.file-name-cell .file-icon{flex-shrink:0;display:flex;align-items:center}.file-name-cell .file-icon svg{width:18px;height:18px}.file-name-cell .name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-name-cell .lock-indicator{font-size:10px;margin-left:6px;padding:1px 5px;border-radius:3px;background:#ff980026;color:var(--warning-color, #f57c00);font-weight:600;flex-shrink:0;white-space:nowrap}.file-size-cell,.file-date-cell,.file-version-cell,.file-modified-by-cell,.file-status-cell,.file-local-cell,.file-star-cell{font-size:var(--font-size-sm);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-local-cell,.file-star-cell{display:flex;align-items:center;justify-content:center}.status-locked{display:inline-flex;align-items:center;gap:4px;color:#e8a838;font-size:11px;font-weight:600}.status-locked svg{flex-shrink:0}.status-unlocked{color:var(--text-muted);opacity:.5;font-size:11px}.col-resizable{position:relative}.col-resize-handle{position:absolute;right:-4px;top:0;bottom:0;width:9px;cursor:col-resize;z-index:2}.col-resize-handle:after{content:"";position:absolute;right:4px;top:2px;bottom:2px;width:1px;background:transparent;transition:background .15s ease,width .1s ease;border-radius:1px}.col-resize-handle:hover:after{background:var(--accent-color);width:2px;right:3px}.file-list-header .sortable-header[draggable=true]{cursor:grab}.file-list-header .sortable-header[draggable=true]:active{cursor:grabbing}.col-drag-over{background:var(--accent-color);opacity:.85;color:#fff;border-radius:3px}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:4px;padding:12px}.file-grid-item{display:flex;flex-direction:column;align-items:center;padding:12px 8px 8px;border-radius:6px;cursor:default;-webkit-user-select:none;user-select:none;text-align:center;transition:background .08s ease;border:2px solid transparent}.file-grid-item:hover{background:var(--bg-hover)}.file-grid-item.selected{background:var(--bg-selected);border-color:var(--accent-color)}.file-grid-icon{display:flex;align-items:center;justify-content:center;margin-bottom:6px}.file-grid-icon svg{width:40px;height:40px}.file-grid-thumbnail{width:100%;aspect-ratio:1;overflow:hidden;border-radius:4px;margin-bottom:6px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center}.file-grid-thumbnail img{width:100%;height:100%;object-fit:cover;border-radius:4px}.file-grid-item.has-thumbnail{padding-top:4px}.file-grid-name{font-size:12px;line-height:1.3;word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%}.file-grid-size{font-size:10px;color:var(--text-muted);margin-top:2px}.file-compact-list{display:flex;flex-direction:column}.file-compact-row{display:flex;align-items:center;gap:6px;padding:3px 12px;cursor:default;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--row-border);min-height:24px;transition:background .08s ease}.file-compact-row:nth-child(2n){background:var(--bg-row-alt)}.file-compact-row:hover{background:var(--bg-hover)}.file-compact-row.selected{background:var(--bg-selected);border-left:2px solid var(--accent-color);padding-left:10px}.file-compact-row .file-icon svg{width:16px;height:16px}.file-compact-row .name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.file-compact-size{font-size:11px;color:var(--text-muted);flex-shrink:0}.view-mode-group{display:flex;border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.view-mode-btn{background:var(--bg-primary);border:none;border-right:1px solid var(--border-color);padding:3px 6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:background .1s,color .1s}.view-mode-btn:last-child{border-right:none}.view-mode-btn:hover{background:var(--bg-hover)}.view-mode-btn.active{background:var(--accent-color);color:#fff}.view-mode-btn svg{width:14px;height:14px}.workspace-badge{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:1px 5px;border-radius:3px;background:var(--accent-color);color:#fff;margin-left:6px;flex-shrink:0}.workspace-badge.outdated{background:var(--warning-color, #f57c00)}.workspace-badge.modified{background:#fdf0d5;color:#b27d00;font-weight:700}.workspace-badge.synced{background:#1a2a3a;color:#4fc3f7;font-weight:600;border:1px solid #4fc3f744}.workspace-badge.cloud-only{background:#2a2230;color:#b39ddb;font-weight:500;border:1px solid #b39ddb44}.workspace-badge.ghost{background:var(--bg-tertiary, #f0f0f0);color:var(--text-muted, #999);font-weight:400;opacity:.8}.workspace-badge.local-only{background:#1a3a2a;color:#4caf50;font-weight:600;border:1px solid #4caf5044}.file-list-row.local-only-row{border-bottom:1px dashed var(--border-color, #333)}.workspace-badge.locally-ignored{background:#2a2a2a;color:#999;font-weight:500;font-style:italic;border:1px solid #99999944}.file-list-row.locally-ignored-row{opacity:.55}.file-list-row.locally-ignored-row:hover{opacity:.8}.status-bar{display:flex;align-items:center;gap:16px;padding:2px 14px;height:24px;background:var(--bg-secondary);border-top:1px solid var(--border-color);font-size:11px;color:var(--text-secondary);flex-shrink:0}.file-list-status-bar{display:flex;align-items:center;gap:10px;padding:2px 10px;height:24px;font-size:10px;color:var(--text-muted);border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.file-list-status-spacer{flex:1}.file-list-status-bar .view-mode-group{margin:0}.file-list-status-bar .view-mode-btn{padding:1px 4px}.file-list-status-bar .view-mode-btn svg{width:12px;height:12px}.status-bar-spacer{flex:1}.status-bar-storage{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);font-weight:500}.status-bar-storage svg{opacity:.6}.status-bar-version{color:var(--text-muted);font-size:10px}.all-files-header{display:flex;align-items:center;gap:6px;padding:2px 8px;background:var(--breadcrumb-bg);border-bottom:1px solid var(--breadcrumb-border);min-height:28px;font-size:var(--font-size-base)}.all-files-back-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;color:var(--text-secondary);border-radius:3px;cursor:pointer;padding:0;transition:background .15s ease,color .15s ease}.all-files-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.all-files-label{font-weight:600;color:var(--text-primary);font-size:12px}.all-files-loading{color:var(--text-muted);font-size:11px;font-style:italic}.all-files-toggle{margin-right:6px}.all-files-toggle.active{background:var(--accent-color);color:#fff}.all-files-toggle.active:hover{background:var(--accent-hover);color:#fff}.file-location-path{display:block;font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;cursor:pointer;line-height:1.2;margin-top:-1px}.file-location-path:hover{color:var(--accent-color);text-decoration:underline}.file-name-cell:has(.file-location-path){flex-wrap:wrap}.file-name-cell:has(.file-location-path) .name{width:calc(100% - 26px)}.file-name-cell:has(.file-location-path) .file-location-path{width:calc(100% - 26px);margin-left:26px}.status-bar-version:hover{color:var(--text-secondary)}.status-bar-update{font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500}.status-bar-update-checking{color:var(--text-muted)}.status-bar-update-available{color:var(--accent-color, #0078d4);background:#0078d414}.status-bar-update-not-available{color:var(--success-color, #2e7d32)}.status-bar-update-downloading{color:var(--accent-color, #0078d4);background:#0078d414}.status-bar-update-downloaded{color:var(--success-color, #2e7d32);background:#2e7d321a;font-weight:600}.status-bar-update-error{color:var(--danger-color, #c62828)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);gap:8px;padding:40px}.empty-state .empty-icon{opacity:.4;margin-bottom:8px}.empty-state .empty-icon svg{width:48px;height:48px}.empty-state .message{font-size:var(--font-size-lg)}.empty-state .hint{font-size:var(--font-size-sm)}.context-menu{position:fixed;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 12px #00000026;padding:4px 0;min-width:220px;z-index:1000;animation:context-menu-in .12s ease}.context-menu-item{display:flex;align-items:center;gap:10px;padding:6px 12px;cursor:pointer;font-size:var(--font-size-base);transition:background .08s ease}.context-menu-item:hover,.context-menu-item.menu-item-focused{background:var(--bg-selected)}.context-menu-item.danger{color:var(--danger-color)}.context-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.context-icon svg{width:14px;height:14px}.context-label{flex:1}.context-shortcut{font-size:11px;color:var(--text-muted);margin-left:auto}.context-menu-separator{height:1px;background:var(--border-color);margin:4px 0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:2000;animation:modal-overlay-in .15s ease}.modal{background:var(--bg-primary);border-radius:8px;box-shadow:0 8px 32px #0003;min-width:400px;max-width:600px;max-height:80vh;overflow-y:auto;animation:modal-card-in .2s ease}.modal-header{padding:16px 20px 12px;font-weight:600;font-size:16px;border-bottom:1px solid var(--border-color)}.modal-body{padding:16px 20px}.modal-footer{padding:12px 20px 16px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--border-color)}.modal-footer button{padding:6px 16px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);transition:background .1s ease,transform .1s ease}.modal-footer button:active{transform:scale(.96)}.modal-footer button.primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.modal-footer button.danger{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.upload-panel{position:fixed;bottom:16px;right:16px;width:360px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #00000026;z-index:500;animation:panel-slide-up .25s ease-out}.upload-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--toolbar-bg);border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0;font-weight:600;font-size:var(--font-size-sm)}.upload-item{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--row-border)}.upload-item .name{flex:1;font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-item .status{font-size:11px;color:var(--text-muted)}.upload-item .status.done{color:var(--success-color)}.upload-item .status.error{color:var(--danger-color)}.progress-bar{height:3px;background:var(--bg-secondary);border-radius:2px;overflow:hidden;margin-top:4px}.progress-bar-fill{height:100%;background:var(--accent-color);transition:width .3s ease;border-radius:2px;position:relative;overflow:hidden}.progress-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);animation:progress-shimmer 1.2s ease-in-out infinite}.upload-action-btn{border:none;background:transparent;cursor:pointer;font-size:13px;color:var(--text-secondary);padding:2px 5px;border-radius:3px;line-height:1}.upload-action-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.upload-item .status.paused{color:#f59e0b}.upload-item .status.uploading{color:var(--accent-color);font-variant-numeric:tabular-nums}.upload-eta{font-size:11px;color:var(--text-muted);margin-left:8px}.upload-auto-dismiss{font-size:11px;color:var(--text-muted);margin-left:auto;animation:upload-dismiss-fade 5s linear forwards}@keyframes upload-dismiss-fade{0%{opacity:1}80%{opacity:1}to{opacity:.3}}.download-panel{position:fixed;bottom:16px;right:16px;width:380px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #00000026;z-index:501;font-size:var(--font-size-sm);animation:panel-slide-up .25s ease-out}.download-panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--toolbar-bg);border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0;font-weight:600}.download-panel-controls{display:flex;gap:4px}.download-panel-btn{border:none;background:transparent;cursor:pointer;font-size:16px;color:var(--text-secondary);padding:0 4px;line-height:1;border-radius:3px}.download-panel-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.download-panel-aggregate{padding:10px 14px 4px}.download-progress-bar{height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.download-progress-fill{height:100%;background:var(--accent-color);border-radius:3px;transition:width .3s ease}.download-panel-stats{display:flex;justify-content:space-between;padding:4px 0;font-size:11px;color:var(--text-muted);font-variant-numeric:tabular-nums}.download-file-list{max-height:200px;overflow-y:auto;border-top:1px solid var(--row-border)}.download-item{display:flex;align-items:center;gap:6px;padding:5px 14px;border-bottom:1px solid var(--row-border)}.download-item-icon{width:16px;text-align:center;font-size:12px;flex-shrink:0}.download-item-icon.downloading{color:var(--accent-color)}.download-item-icon.done{color:var(--success-color)}.download-item-icon.pending{color:var(--text-muted)}.download-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.download-item-status{font-size:11px;color:var(--text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.download-item-status.downloading{color:var(--accent-color)}.download-item-status.done{color:var(--success-color)}.concurrency-slider{display:flex;align-items:center;gap:8px;padding:6px 14px;font-size:12px;color:var(--text-secondary)}.concurrency-slider label{white-space:nowrap;min-width:74px;font-variant-numeric:tabular-nums}.concurrency-slider input[type=range]{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;outline:none}.concurrency-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-color);cursor:pointer;border:2px solid var(--bg-primary);box-shadow:0 1px 3px #0003}.concurrency-slider input[type=range]:disabled{opacity:.5}.concurrency-slider .value{min-width:20px;text-align:center;font-variant-numeric:tabular-nums}.version-panel{width:360px;min-width:280px;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.version-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color);font-weight:600}.version-panel-body{flex:1;overflow-y:auto}.version-item{padding:10px 16px;border-bottom:1px solid var(--row-border);cursor:pointer;transition:background .08s ease}.version-item:hover{background:var(--bg-hover)}.version-item .version-num{font-weight:600;color:var(--accent-color)}.version-item .version-meta{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:2px}.version-item .version-actions{margin-top:6px;display:flex;gap:8px}.version-item .version-actions button{padding:2px 8px;font-size:11px;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-family:var(--font-family);transition:background .1s ease}.version-item .version-actions button:hover{background:var(--bg-hover)}.preview-resize-handle{width:4px;cursor:col-resize;flex-shrink:0;background:transparent;position:relative;z-index:10;transition:background .15s}.preview-resize-handle:hover,.preview-resize-handle.dragging{background:var(--accent-color, #0078d4)}.preview-panel{width:420px;min-width:280px;max-width:900px;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.preview-panel.preview-panel-expanded{position:fixed;top:40px;left:0;right:0;bottom:0;width:auto!important;max-width:none;z-index:100;border-left:none}.preview-nav-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#ccc;font-size:18px;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}.preview-nav-btn:hover{background:#ffffff14;border-color:#ffffff4d;color:#fff}[data-theme=light] .preview-nav-btn{border-color:#00000026;color:#666}[data-theme=light] .preview-nav-btn:hover{background:#0000000f;border-color:#0000004d;color:#333}.preview-expand-btn{border:none;background:transparent;cursor:pointer;font-size:16px;color:var(--text-secondary);padding:0 4px;line-height:1}.preview-expand-btn:hover{color:var(--text-primary)}.preview-panel-expanded .preview-video-container{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:16px}.preview-panel-expanded .preview-video{max-width:100%;max-height:100%;width:auto;height:auto}.preview-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-color);gap:10px;min-height:44px}.preview-panel-title{display:flex;align-items:center;gap:10px;overflow:hidden;flex:1}.preview-panel-file-info{display:flex;flex-direction:column;overflow:hidden}.preview-panel-name{font-weight:600;font-size:var(--font-size-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-panel-meta{font-size:11px;color:var(--text-secondary)}.preview-panel-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.preview-controls{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 8px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.preview-controls button{padding:2px 8px;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);font-size:12px;color:var(--text-primary)}.preview-controls button:hover:not(:disabled){background:var(--bg-hover)}.preview-controls button:disabled{opacity:.4;cursor:default}.preview-zoom-level{font-size:11px;color:var(--text-secondary);min-width:50px;text-align:center}.preview-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;color:var(--text-muted);font-size:var(--font-size-base)}.preview-spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top:2px solid var(--accent-color);border-radius:50%;animation:preview-spin .8s linear infinite}@keyframes preview-spin{to{transform:rotate(360deg)}}.preview-error{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:8px;color:var(--text-muted);font-size:var(--font-size-base)}.preview-image-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-image-scroll{flex:1;overflow:auto;display:flex;align-items:start;justify-content:center;padding:8px}.preview-image-container:fullscreen{background:#000}.preview-image-container:fullscreen .preview-image-scroll{align-items:center}.preview-image-container:fullscreen .preview-controls{background:#0009;border-color:#ffffff26}.preview-image-container:fullscreen .preview-controls button{background:#ffffff1a;color:#fff;border-color:#fff3}.preview-image-container:fullscreen .preview-controls button:hover{background:#fff3}.preview-image-container:fullscreen .preview-zoom-level{color:#ccc}.preview-video-container{width:100%;padding:8px}.preview-video{width:100%;max-height:100%;border-radius:4px;background:#000}.preview-audio-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;padding:32px}.preview-audio-icon{font-size:64px;opacity:.4;-webkit-user-select:none;user-select:none}.preview-audio-filename{font-size:15px;color:#ccc;text-align:center;word-break:break-word;max-width:300px}.preview-audio-player{width:100%;max-width:400px;margin-top:8px;border-radius:8px}.preview-pdf-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-pdf-scroll{flex:1;overflow:auto;padding:8px;background:var(--bg-secondary)}.preview-pdf-scroll canvas{display:block;margin:0 auto;box-shadow:0 1px 4px #00000026;min-width:fit-content}.preview-docx-outer{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-docx-container{flex:1;overflow:auto;background:#e8e8e8}.preview-docx-content{transform-origin:top center}.preview-docx-content .docx-wrapper{background:#e8e8e8!important}.preview-xlsx-outer{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-xlsx-tabs{display:flex;gap:0;padding:0 8px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);overflow-x:auto;flex-shrink:0}.preview-xlsx-tab{padding:6px 14px;border:none;background:transparent;color:var(--text-secondary);font-size:12px;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap}.preview-xlsx-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.preview-xlsx-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.preview-xlsx-scroll{flex:1;overflow:auto;background:var(--bg-primary)}.preview-xlsx-content table{border-collapse:collapse;width:max-content;min-width:100%;font-size:13px}.preview-xlsx-content td,.preview-xlsx-content th{border:1px solid var(--border-color);padding:4px 8px;white-space:nowrap;max-width:300px;overflow:hidden;text-overflow:ellipsis}.preview-xlsx-content th{background:var(--bg-secondary);font-weight:600;position:sticky;top:0;z-index:1}.preview-xlsx-content tr:hover td{background:var(--bg-hover)}.preview-code-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.preview-code-scroll{flex:1;overflow:scroll}.preview-code-content{min-height:100%}.preview-code-editor{width:100%;height:100%;min-height:100%;padding:16px;margin:0;border:none;outline:none;resize:none;font-size:13px;line-height:1.5;font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;background:var(--bg-secondary, #f6f8fa);color:var(--text-primary);-moz-tab-size:2;tab-size:2;white-space:pre;overflow-wrap:normal;box-sizing:border-box}.preview-code-content pre.shiki{margin:0;padding:16px;font-size:13px;line-height:1.5;font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;min-height:100%;border-radius:0;white-space:pre;width:fit-content;min-width:100%}.preview-code-content pre.shiki code{counter-reset:line}.preview-code-content pre.shiki code .line{display:inline-block;width:100%}.preview-code-content pre.shiki code .line:before{counter-increment:line;content:counter(line);display:inline-block;width:3em;margin-right:1em;text-align:right;color:var(--text-muted, #6e7681);opacity:.5;font-size:12px;-webkit-user-select:none;user-select:none}.import-folder-dialog{position:relative;background:var(--bg-primary);border-radius:8px;width:90vw;max-width:600px;padding:20px;box-shadow:0 8px 32px #0000004d;animation:modal-card-in .2s ease}.text-conflict-dialog{position:relative;background:var(--bg-primary);border-radius:8px;width:90vw;max-width:1200px;height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;overflow:hidden;animation:modal-card-in .2s ease}.text-conflict-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 20px 12px;border-bottom:1px solid var(--border-color);flex-shrink:0}.text-conflict-status{padding:8px 20px;font-size:12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.text-conflict-diff{flex:1;overflow:auto;min-height:0}.text-conflict-actions{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-color);flex-shrink:0}.conflict-btn{padding:6px 16px;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500}.conflict-btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.conflict-btn-danger{background:var(--danger-color, #d32f2f);color:#fff}.conflict-btn-primary{background:var(--accent-color, #0078d4);color:#fff}.conflict-btn:hover{opacity:.9}.conflict-view-btn{padding:4px 10px;font-size:11px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:3px}.conflict-view-btn.active{background:var(--accent-color, #0078d4);color:#fff;border-color:var(--accent-color, #0078d4)}.diff-split-container{display:flex;flex-direction:column;height:100%}.diff-split-header{display:flex;border-bottom:1px solid var(--border-color);flex-shrink:0}.diff-split-label{flex:1;padding:6px 12px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-secondary)}.diff-split-label+.diff-split-label{border-left:1px solid var(--border-color)}.diff-split-body{display:flex;flex:1;overflow:auto;min-height:0}.diff-split-pane{flex:1;overflow-x:auto;min-width:0}.diff-split-pane+.diff-split-pane{border-left:1px solid var(--border-color)}.diff-unified-container{height:100%;overflow:auto}.diff-code{margin:0;font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;font-size:12px;line-height:1.6;width:fit-content;min-width:100%}.diff-virtualized{overflow:auto;flex:1;min-height:0}.diff-line{display:flex;min-height:1.6em;white-space:pre}.diff-line-num{display:inline-block;min-width:3em;padding:0 8px 0 4px;text-align:right;color:var(--text-muted);opacity:.6;-webkit-user-select:none;user-select:none;flex-shrink:0;font-size:11px}.diff-line-prefix{display:inline-block;width:1.5em;text-align:center;flex-shrink:0;font-weight:700}.diff-line-content{flex:1;padding-right:8px}.diff-line.diff-added{background:#2ea04326}.diff-line.diff-added .diff-line-prefix{color:#2ea043}.diff-line.diff-removed{background:#f8514926}.diff-line.diff-removed .diff-line-prefix{color:#f85149}.diff-line.diff-added .diff-token-highlight{background:#2ea04366;border-radius:2px}.diff-line.diff-removed .diff-token-highlight{background:#f8514966;border-radius:2px}.diff-line.diff-conflict-local{background:#f8514933;border-left:3px solid #f85149}.diff-line.diff-conflict-remote{background:#2ea04333;border-left:3px solid #2ea043}.diff-line.diff-conflict-marker{background:#8250df26;color:var(--text-muted);font-weight:700;font-style:italic}.diff-line.diff-conflict-local,.diff-line.diff-conflict-remote,.diff-line.diff-conflict-accepted,.diff-line.diff-conflict-rejected{position:relative}.diff-line.diff-conflict-accepted{background:#2ea0432e;border-left:3px solid #2ea043}.diff-line.diff-conflict-rejected{background:#8080800f;border-left:3px solid var(--border-color);opacity:.45}.diff-line.diff-conflict-rejected .diff-line-content{text-decoration:line-through;text-decoration-color:var(--text-muted)}.conflict-inline-btn{position:absolute;top:0;right:4px;font-size:10px;padding:0 8px;height:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:3px;cursor:pointer;opacity:0;transition:opacity .15s;z-index:1;font-family:inherit;white-space:nowrap;display:flex;align-items:center}.diff-line:hover .conflict-inline-btn{opacity:.85}.conflict-inline-btn:hover{opacity:1!important}.conflict-inline-btn.conflict-inline-local:hover{background:#f85149;border-color:#f85149;color:#fff}.conflict-inline-btn.conflict-inline-remote:hover{background:#2ea043;border-color:#2ea043;color:#fff}.conflict-inline-btn.accepted{opacity:1;font-weight:600}.conflict-inline-btn.conflict-inline-local.accepted{background:#f8514933;border-color:#f85149;color:#f85149}.conflict-inline-btn.conflict-inline-remote.accepted{background:#2ea04333;border-color:#2ea043;color:#2ea043}.conflict-hunks-panel{border-bottom:1px solid var(--border-color);padding:6px 12px;display:flex;flex-wrap:wrap;gap:6px;background:var(--bg-secondary);flex-shrink:0}.conflict-hunk-row{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;background:var(--bg-primary);border:1px solid var(--border-color);font-size:12px}.conflict-hunk-row.resolved{border-color:var(--success-color, #2e7d32);background:#2ea04314}.conflict-hunk-label{font-weight:600;font-size:11px;white-space:nowrap}.conflict-hunk-btn{padding:2px 8px;font-size:10px;border:1px solid var(--border-color);border-radius:3px;cursor:pointer;background:var(--bg-secondary);color:var(--text-secondary)}.conflict-hunk-btn:hover{opacity:.85}.conflict-hunk-btn.active-local{background:#f8514933;border-color:#f85149;color:#f85149;font-weight:600}.conflict-hunk-btn.active-remote{background:#2ea04333;border-color:#2ea043;color:#2ea043;font-weight:600}.conflict-btn-mini{padding:2px 8px;font-size:10px;border:1px solid var(--border-color);border-radius:3px;cursor:pointer;background:var(--bg-secondary);color:var(--text-secondary)}.conflict-btn-mini:hover{opacity:.85}.conflict-merged-editor{height:100%;display:flex;flex-direction:column}.conflict-merged-textarea{flex:1;width:100%;resize:none;font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;font-size:12px;line-height:1.6;padding:8px;border:none;outline:none;background:var(--bg-primary);color:var(--text-primary);-moz-tab-size:2;tab-size:2}.auth-page{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-secondary)}.boot-logo-pulse{animation:boot-pulse 1.8s ease-in-out infinite}.auth-card{background:var(--bg-primary);border-radius:8px;box-shadow:var(--shadow-light);padding:32px;width:380px}.auth-card h2{margin-bottom:24px;text-align:center}.auth-card .form-group{margin-bottom:16px}.auth-card label{display:block;margin-bottom:4px;font-size:var(--font-size-sm);font-weight:500}.auth-card input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:var(--font-size-base);font-family:var(--font-family);background:var(--input-bg);color:var(--text-primary)}.auth-card input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #0078d433}.auth-card .submit-btn{width:100%;padding:10px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;font-size:var(--font-size-lg);cursor:pointer;font-family:var(--font-family);font-weight:500}.auth-card .submit-btn:hover{background:#106ebe}.auth-card .error-msg{color:var(--danger-color);font-size:var(--font-size-sm);margin-bottom:12px;text-align:center}.auth-card .toggle-link{text-align:center;margin-top:16px;font-size:var(--font-size-sm)}.auth-card .toggle-link a{color:var(--accent-color);cursor:pointer;text-decoration:none}.modal-dialog{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:20px;min-width:320px;max-width:400px;box-shadow:0 8px 32px #00000040;animation:modal-card-in .2s ease}.modal-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:12px;color:var(--text-primary)}.drop-zone-active{position:fixed;top:0;left:0;right:0;bottom:0;background:#0078d41a;border:3px dashed var(--accent-color);display:flex;align-items:center;justify-content:center;z-index:999;pointer-events:none;animation:modal-overlay-in .2s ease,drop-zone-pulse 1.5s ease-in-out .2s infinite}.drop-zone-active .drop-message{font-size:20px;color:var(--accent-color);font-weight:600}.drop-zone-close{position:absolute;top:12px;right:12px;pointer-events:auto;background:var(--bg-secondary, #f0f0f0);border:1px solid var(--border-color, #ccc);border-radius:50%;width:32px;height:32px;font-size:20px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #666);transition:background .15s,color .15s}.drop-zone-close:hover{background:var(--bg-hover, #e0e0e0);color:var(--text-primary, #333)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#606060}.file-list-container,.projects-panel-list,.sidebar-scroll-area,.notification-list{background:linear-gradient(var(--bg-primary) 30%,transparent) center top,linear-gradient(transparent,var(--bg-primary) 70%) center bottom,radial-gradient(farthest-side at 50% 0,rgba(0,0,0,.12),transparent) center top,radial-gradient(farthest-side at 50% 100%,rgba(0,0,0,.12),transparent) center bottom;background-repeat:no-repeat;background-size:100% 40px,100% 40px,100% 10px,100% 10px;background-attachment:local,local,scroll,scroll}.projects-panel-list,.sidebar-scroll-area{background:linear-gradient(var(--bg-sidebar) 30%,transparent) center top,linear-gradient(transparent,var(--bg-sidebar) 70%) center bottom,radial-gradient(farthest-side at 50% 0,rgba(0,0,0,.1),transparent) center top,radial-gradient(farthest-side at 50% 100%,rgba(0,0,0,.1),transparent) center bottom;background-repeat:no-repeat;background-size:100% 40px,100% 40px,100% 8px,100% 8px;background-attachment:local,local,scroll,scroll}.theme-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;border:1px solid transparent;border-radius:3px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:16px;line-height:1}.theme-toggle:hover{background:var(--bg-hover);border-color:var(--border-color)}.right-column{width:var(--right-panel-width, 340px);min-width:240px;flex-shrink:0;display:flex;flex-direction:column;overflow:hidden;border-left:1px solid var(--border-color);background:var(--bg-primary);transition:width .15s ease,min-width .15s ease}.right-column.collapsed{width:32px!important;min-width:32px!important;overflow:hidden}.right-column.collapsed .right-column-header,.right-column.collapsed .right-column-body{display:none}.right-column-expand-strip{display:none;align-items:center;justify-content:center;flex:1;cursor:pointer;writing-mode:vertical-rl;text-orientation:mixed;font-size:11px;font-weight:600;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;-webkit-user-select:none;user-select:none;transition:color .15s,background .15s}.right-column.collapsed .right-column-expand-strip{display:flex}.right-column-expand-strip:hover{color:var(--text-primary);background:var(--bg-hover)}.right-column-resize-handle{width:4px;cursor:col-resize;flex-shrink:0;background:transparent;transition:background .15s}.right-column-resize-handle:hover{background:var(--accent-color, #2196f3)}.right-column-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-color);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease}.right-column-header:hover{background:var(--bg-hover)}.right-column-toggle{font-size:10px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:3px;transition:background .15s ease}.right-column-toggle:hover{background:var(--bg-primary)}.right-column-tabs{display:flex;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.right-column-tab{flex:1;padding:6px 8px;font-size:11px;font-weight:600;text-align:center;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);cursor:pointer;font-family:var(--font-family);transition:color .15s,border-color .15s}.right-column-tab:hover{color:var(--text-primary)}.right-column-tab.active{color:var(--accent-color, #0078d4);border-bottom-color:var(--accent-color, #0078d4)}.right-column-body{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column}.sidebar-storage-hint{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-secondary);padding:2px 14px 6px}.sidebar-storage-hint svg{flex-shrink:0;opacity:.6}.sidebar-shortcuts-hint{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:10px;color:var(--text-muted);cursor:pointer;border-top:1px solid var(--border-color);transition:color .15s,background .15s}.sidebar-shortcuts-hint:hover{color:var(--text-secondary);background:var(--bg-hover)}.sidebar-shortcuts-hint svg{flex-shrink:0;opacity:.5}.ws-panel{width:400px;min-width:300px;flex-shrink:0;overflow:hidden}.ws-panel.ws-panel-embedded{width:auto;min-width:0;border-left:none;flex-shrink:1;display:flex;flex-direction:column;height:100%}.ws-toolbar{padding:6px 10px;border-bottom:1px solid var(--border-color);display:flex;gap:6px;align-items:center;background:var(--bg-secondary)}.ws-btn{padding:5px 10px;font-size:11px;font-weight:500;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);color:var(--text-primary);height:28px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .1s ease}.ws-btn svg{width:12px;height:12px;flex-shrink:0;vertical-align:middle}.ws-btn:hover{background:var(--bg-hover);border-color:var(--text-muted)}.ws-btn:active:not(:disabled){transform:scale(.96)}.ws-btn:disabled{opacity:.45;cursor:default}.ws-btn-primary{border-color:var(--accent-color);background:var(--accent-color);color:#fff;font-weight:600}.ws-btn-primary:hover{opacity:.92;box-shadow:0 2px 8px #0078d440}.ws-section{border-bottom:1px solid var(--border-color)}.ws-section-label{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.ws-section-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ws-file-item{display:flex;align-items:center;justify-content:space-between;padding:8px 14px 8px 34px;border-bottom:1px solid var(--row-border);gap:10px;transition:background .1s ease}.ws-file-item:hover{background:var(--bg-hover)}.ws-file-info{display:flex;align-items:flex-start;gap:8px;flex:1;min-width:0}.ws-file-badge{width:20px;height:20px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}.ws-badge-modified{background:#fdf0d5;color:#b27d00}.ws-badge-new{background:#e8f5e9;color:#2e7d32}.ws-badge-removed{background:#ffebee;color:#c62828}.ws-file-details{display:flex;flex-direction:column;min-width:0}.ws-file-name{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-file-name-removed{text-decoration:line-through;opacity:.7}.ws-file-path{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-file-meta{font-size:11px;color:var(--text-secondary)}.ws-file-actions{display:flex;gap:4px;flex-shrink:0}.ws-action-btn{padding:4px 10px;font-size:11px;font-weight:500;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);color:var(--text-primary);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;white-space:nowrap}.ws-action-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);box-shadow:0 1px 3px #00000014}.ws-action-btn:disabled{opacity:.4;cursor:default}.ws-action-btn-push{border-color:var(--accent-color, #0078d4);color:var(--accent-color, #0078d4);font-weight:600}.ws-action-btn-push:hover{background:#0078d414;border-color:var(--accent-color, #0078d4)}.ws-action-btn-upload{border-color:#4caf50;color:#2e7d32;font-weight:600}.ws-action-btn-upload:hover{background:#4caf5014;border-color:#4caf50}.ws-sync-summary{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-wrap:wrap}.ws-sync-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.ws-sync-push{background:#e8a83826;color:#e8a838}.ws-sync-pull{background:#0078d41f;color:var(--accent-color, #0078d4)}.ws-sync-conflict{background:#e539351f;color:#e53935}.ws-btn-pull{background:var(--accent-color, #0078d4);color:#fff;border-color:var(--accent-color, #0078d4);font-weight:600}.ws-btn-pull:hover{opacity:.92;box-shadow:0 2px 8px #0078d440}.ws-btn-loading{opacity:.7;cursor:wait}@keyframes ws-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ws-spin{animation:ws-spin .8s linear infinite}.ws-action-ignore{color:var(--text-muted)!important;border-style:dashed!important}.ws-action-ignore:hover{background:#e5393514!important;color:#e53935!important;border-color:#e53935!important}.ws-section-actions{display:flex;gap:8px;padding:6px 14px 6px 34px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.ws-action-btn-sm{font-size:10px!important;padding:3px 8px!important}.ws-compact-row{display:flex;align-items:center;gap:8px;padding:4px 14px;cursor:default;transition:background .1s ease;font-size:12px;-webkit-user-select:none;user-select:none}.ws-compact-row:hover{background:var(--bg-hover)}.ws-compact-indicator{width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;line-height:1}.ws-indicator-modified{background:#e8a83826;color:#e8a838}.ws-indicator-new{background:#4caf5026;color:#4caf50}.ws-indicator-removed{background:#e5393526;color:#e53935}.ws-compact-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.ws-compact-name-removed{text-decoration:line-through;opacity:.6}.ws-compact-ext{font-size:10px;color:var(--text-muted);flex-shrink:0;min-width:32px;text-align:center}.ws-compact-meta{font-size:10px;color:var(--text-muted);flex-shrink:0;min-width:40px;text-align:right}.ws-compact-modified{border-left:2px solid #e8a838}.ws-compact-new{border-left:2px solid #4caf50}.ws-compact-removed{border-left:2px solid #e53935}.ws-compact-pull{border-left:2px solid var(--accent-color, #1a73e8)}.ws-indicator-pull{background:#1a73e826;color:var(--accent-color, #1a73e8)}.ws-btn-fetch{border-color:var(--accent-color, #1a73e8);background:var(--accent-color, #1a73e8);color:#fff;font-weight:600}.ws-btn-fetch:hover{opacity:.92;box-shadow:0 2px 8px #0078d440}.ws-btn-fetch svg{stroke:#fff}.ws-sort-select{padding:4px 8px;font-size:11px;height:28px;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);color:var(--text-secondary);cursor:pointer;font-family:var(--font-family);margin-left:auto}.ws-section-label-actions{margin-left:auto;display:flex;gap:6px}.ws-label-btn{font-size:11px;padding:3px 10px;border:1px solid #388e3c;border-radius:5px;background:#388e3c1f;color:#4caf50;cursor:pointer;font-family:var(--font-family);font-weight:600;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap}.ws-label-btn:hover{background:#388e3c40;color:#66bb6a;box-shadow:0 1px 4px #388e3c33}.ws-label-btn:disabled{opacity:.5;cursor:not-allowed}.ws-label-btn-muted{color:var(--text-muted);border-color:var(--border-color);background:transparent;font-weight:500}.ws-label-btn-muted:hover{color:#ef5350;border-color:#e53935;background:#e539351a;box-shadow:0 1px 4px #e5393526}.ws-truncated-summary{padding:10px 14px;font-size:11px;line-height:1.5;color:var(--text-muted);background:var(--bg-secondary);border-top:1px solid var(--border-color)}.ph-panel{padding:0;overflow-y:auto;height:100%}.ph-loading,.ph-error,.ph-empty{padding:20px 14px;font-size:12px;color:var(--text-muted);text-align:center}.ph-error{color:var(--danger-color, #c62828)}.ph-group{border-bottom:1px solid var(--border-color)}.ph-group-header{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;cursor:pointer;transition:background .1s}.ph-group-header:hover{background:var(--bg-hover)}.ph-group-expanded{background:var(--bg-secondary)}.ph-icon{font-size:12px;width:18px;text-align:center;flex-shrink:0;padding-top:1px}.ph-group-info{flex:1;min-width:0}.ph-group-summary{font-size:11px;color:var(--text-primary);line-height:1.4;word-break:break-word}.ph-group-summary strong{font-weight:600}.ph-file-count{font-weight:600;color:var(--accent-color, #0078d4)}.ph-file-name{font-weight:500;color:var(--text-secondary)}.ph-group-comment{font-size:10px;color:var(--text-secondary);font-style:italic;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ph-group-time{font-size:10px;color:var(--text-muted);margin-top:2px}.ph-expand-arrow{font-size:9px;color:var(--text-muted);flex-shrink:0;padding-top:2px}.ph-group-files{background:var(--bg-secondary);border-top:1px solid var(--border-color)}.ph-file-row{display:flex;align-items:center;gap:6px;padding:4px 12px 4px 38px;font-size:11px;cursor:pointer;transition:background .1s}.ph-file-row:hover{background:var(--bg-hover)}.ph-file-row-name{color:var(--text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ph-file-row-path{color:var(--text-muted);font-size:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-left:auto}.ph-badge-new{display:inline-block;font-size:9px;padding:0 4px;border-radius:3px;background:var(--accent, #4f8ff7);color:#fff;margin-left:4px;vertical-align:middle;line-height:14px}.ws-push-bar{display:flex;flex-direction:column;gap:6px;padding:8px 10px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.ws-push-summary{width:100%;padding:5px 8px;font-size:11px;font-family:var(--font-family);border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);outline:none;box-sizing:border-box}.ws-push-summary:focus{border-color:var(--accent-color, #0078d4)}.ws-push-description{width:100%;padding:5px 8px;font-size:11px;font-family:var(--font-family);border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);outline:none;resize:vertical;min-height:32px;max-height:80px;box-sizing:border-box}.ws-push-description:focus{border-color:var(--accent-color, #0078d4)}.ws-push-btn{width:100%;justify-content:center;height:30px;font-size:12px}.ws-push-progress{width:100%;height:3px;background:var(--border-color);border-radius:2px;overflow:hidden;position:relative}.ws-push-progress-fill{height:100%;background:var(--accent-color, #3b82f6);border-radius:2px;transition:width .15s ease-out}.ws-push-current-file{width:100%;font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:1px 4px;opacity:.7}.ws-push-active-uploads{width:100%;display:flex;flex-direction:column;gap:2px;padding:2px 4px 4px;max-height:120px;overflow-y:auto}.ws-push-active-file{display:grid;grid-template-columns:1fr 32px;grid-template-rows:auto 3px;gap:0 4px;align-items:center;font-size:10px;color:var(--text-secondary)}.ws-push-active-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.ws-push-active-pct{text-align:right;font-variant-numeric:tabular-nums;font-size:9px;opacity:.7}.ws-push-active-bar{grid-column:1 / -1;height:3px;background:var(--border-color);border-radius:1.5px;overflow:hidden}.ws-push-active-bar-fill{height:100%;background:var(--accent-color, #3b82f6);border-radius:1.5px;transition:width .15s ease-out}.ws-pull-progress-section{padding:4px 8px 6px;display:flex;flex-direction:column;gap:2px}.ws-pull-progress-fill,.ws-pull-bar-fill{background:#22c55e!important}.ws-ctx-menu{position:fixed;z-index:9999;min-width:200px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px #0003;padding:4px 0;font-size:12px}.ws-ctx-item{display:flex;align-items:center;gap:8px;padding:7px 14px;cursor:pointer;color:var(--text-primary);transition:background .1s}.ws-ctx-item:hover{background:var(--bg-hover)}.ws-ctx-item svg{flex-shrink:0;opacity:.7}.ws-ctx-primary{font-weight:600;color:var(--accent-color, #0078d4)}.ws-ctx-danger{color:#e53935}.ws-ctx-separator{height:1px;background:var(--border-color);margin:4px 0}.ws-sync-controls{display:flex;align-items:center;gap:6px;padding:8px 14px;border-bottom:1px solid var(--border-color);flex-wrap:wrap}.ws-sync-ctrl-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;border:1px solid var(--border-color);border-radius:5px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);color:var(--text-secondary);transition:background .15s,border-color .15s,color .15s}.ws-sync-ctrl-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.ws-sync-ctrl-danger{color:var(--danger-color, #d32f2f);border-color:transparent}.ws-sync-ctrl-danger:hover{background:#d32f2f14;border-color:var(--danger-color, #d32f2f)}.ws-sync-path{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer;max-width:200px}.ws-sync-path:hover{color:var(--accent-color, #0078d4);text-decoration:underline}.diff-split-body-sync{display:flex;flex:1;overflow:hidden;min-height:0}.diff-split-pane-sync{flex:1;overflow:auto;min-width:0}.diff-split-divider{width:1px;background:var(--border-color);flex-shrink:0}.diff-line.diff-blank{background:var(--bg-secondary);opacity:.5}.diff-dialog{width:96vw;max-width:none;height:94vh;background:var(--bg-primary);border-radius:8px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000004d;animation:modal-card-in .2s ease}.ghd-body{flex:1;display:flex;overflow:hidden;min-height:0}.ghd-file-sidebar{width:240px;min-width:200px;border-right:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--bg-secondary)}.ghd-file-sidebar-header{padding:8px 12px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color)}.ghd-file-sidebar-list{flex:1;overflow-y:auto}.ghd-file-sidebar-item{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;border-left:3px solid transparent;transition:background .1s}.ghd-file-sidebar-item:hover{background:var(--hover-bg)}.ghd-file-sidebar-item.active{background:var(--accent-color-alpha, rgba(0, 120, 212, .12));border-left-color:var(--accent-color, #0078d4)}.ghd-file-sidebar-name{font-size:12px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.diff-dialog-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);gap:12px}.diff-dialog-body{flex:1;overflow:auto}.inline-diff-view{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.inline-diff-header{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);gap:8px;flex-shrink:0}.inline-diff-back-btn{background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;padding:4px 6px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);flex-shrink:0}.inline-diff-back-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.inline-diff-file-info{display:flex;align-items:center;gap:8px;min-width:0;flex-shrink:1}.inline-diff-filename{font-weight:600;font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-diff-path{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inline-diff-stats{display:inline-flex;gap:6px;font-size:12px;font-family:var(--font-mono, "Cascadia Code", "Consolas", monospace);flex-shrink:0}.inline-diff-stat-add{color:#2ea043}.inline-diff-stat-del{color:#f85149}.inline-diff-stat-mod{color:#fb8c00}.inline-diff-spacer{flex:1}.inline-diff-controls{display:flex;gap:2px;flex-shrink:0}.inline-diff-mode-btn{background:transparent;border:1px solid var(--border-color);border-radius:3px;padding:3px 10px;font-size:11px;cursor:pointer;color:var(--text-secondary)}.inline-diff-mode-btn:hover{background:var(--bg-hover)}.inline-diff-mode-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.inline-diff-push-btn{display:flex;align-items:center;gap:4px;background:var(--accent-color);color:#fff;border:none;border-radius:4px;padding:4px 12px;font-size:12px;cursor:pointer;flex-shrink:0}.inline-diff-push-btn:hover{opacity:.9}.inline-diff-body{display:flex;flex:1;overflow:hidden;min-height:0}.inline-diff-sidebar{width:200px;min-width:150px;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;background:var(--bg-primary)}.inline-diff-sidebar-header{padding:8px 10px;font-size:11px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.inline-diff-sidebar-list{overflow-y:auto;flex:1}.inline-diff-sidebar-item{display:flex;align-items:center;gap:6px;padding:5px 10px;cursor:pointer;font-size:12px;border-left:2px solid transparent}.inline-diff-sidebar-item:hover{background:var(--bg-hover)}.inline-diff-sidebar-item.active{background:var(--bg-hover);border-left-color:var(--accent-color)}.inline-diff-sidebar-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary);font-size:12px}.inline-diff-content{flex:1;overflow:hidden;min-width:0;display:flex}.diff-with-minimap{display:flex;flex:1;min-height:0;min-width:0}.diff-with-minimap>.diff-code,.diff-with-minimap>.diff-split-container{flex:1;min-width:0}.diff-minimap{width:44px;flex-shrink:0;position:relative;background:var(--bg-secondary);border-left:1px solid var(--border-color);cursor:pointer;-webkit-user-select:none;user-select:none}.diff-minimap-canvas{display:block;width:100%;height:100%}.diff-minimap-viewport{position:absolute;left:0;right:0;background:#ffffff14;border-top:1px solid rgba(255,255,255,.2);border-bottom:1px solid rgba(255,255,255,.2);pointer-events:none;transition:top .05s ease-out}.diff-minimap:hover .diff-minimap-viewport{background:#ffffff1f}.inline-diff-placeholder{display:flex;align-items:center;justify-content:center;flex:1;padding:32px;color:var(--text-muted);font-size:13px}.inline-diff-error{color:var(--danger-color, #d32f2f)}.binary-diff-container{display:flex;flex:1;min-height:0}.binary-diff-pane{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.binary-diff-pane+.binary-diff-pane{border-left:1px solid var(--border-color)}.binary-diff-label{padding:6px 12px;font-size:11px;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0;text-align:center}.binary-diff-preview{flex:1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:16px;background:var(--bg-primary)}.binary-diff-preview img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:0 1px 4px #0000001a}.binary-diff-preview video{max-width:100%;max-height:100%;border-radius:4px}.inline-diff-binary-info{display:flex;align-items:center;justify-content:center;flex:1;padding:32px}.binary-info-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary)}.binary-info-text{font-size:14px;font-weight:600;color:var(--text-primary)}.binary-info-details{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px;color:var(--text-muted)}.ws-diff-stats{display:inline-flex;gap:4px;margin-left:4px;font-size:10px;font-family:var(--font-mono, "Cascadia Code", "Consolas", monospace);flex-shrink:0}.ws-diff-stat-add{color:#2ea043}.ws-diff-stat-del{color:#f85149}.ws-diff-stat-mod{color:#fb8c00}.ws-diff-stats-loading{display:inline-flex;gap:3px;margin-left:4px}.ws-diff-stats-loading>span{display:inline-block;width:18px;height:8px;border-radius:3px;background:linear-gradient(90deg,var(--bg-tertiary, #e0e0e0) 25%,var(--bg-hover, #f0f0f0) 50%,var(--bg-tertiary, #e0e0e0) 75%);background-size:200% 100%;animation:ws-shimmer 1.2s ease-in-out infinite}.ws-diff-stats-loading>span:nth-child(2){animation-delay:.15s}@keyframes ws-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}[data-theme=dark] .ws-diff-stats-loading>span{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff1f,#ffffff0f 75%);background-size:200% 100%;animation:ws-shimmer 1.2s ease-in-out infinite}.ws-compact-row.ws-compact-modified{cursor:pointer}.ws-compact-row.ws-compact-modified:hover{background:var(--bg-hover)}.ws-row-revert-btn{display:none;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:2px;border-radius:3px;margin-left:auto;flex-shrink:0;transition:color .15s,background .15s}.ws-compact-row:hover .ws-row-revert-btn{display:flex}.ws-row-revert-btn:hover{color:var(--danger-color, #d32f2f);background:#d32f2f1a}.inline-conflict-view .text-conflict-status{flex-shrink:0}.inline-conflict-view .conflict-hunks-panel{flex-shrink:0;max-height:120px;overflow-y:auto}.inline-conflict-view .text-conflict-diff{flex:1;overflow:hidden;display:flex;flex-direction:column}.inline-conflict-view .text-conflict-actions{flex-shrink:0;display:flex;justify-content:flex-end;gap:8px;padding:8px 12px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}[data-theme=dark] .inline-diff-stat-add,[data-theme=dark] .ws-diff-stat-add{color:#3fb950}[data-theme=dark] .inline-diff-stat-del,[data-theme=dark] .ws-diff-stat-del{color:#f85149}[data-theme=dark] .inline-diff-stat-mod,[data-theme=dark] .ws-diff-stat-mod{color:#ffa726}[data-theme=dark] .binary-diff-preview img{box-shadow:0 1px 4px #0000004d}.notification-bell{position:relative;margin-right:4px}.notification-bell .toolbar-btn{position:relative}.notification-badge{position:absolute;top:-2px;right:0;min-width:16px;height:16px;border-radius:8px;background:var(--danger-color);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none;line-height:1}.notification-dropdown{width:320px;max-height:400px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0000002e,0 2px 8px #0000001a;display:flex;flex-direction:column;overflow:hidden;opacity:0;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease}.notification-dropdown-visible{opacity:1;transform:translateY(0)}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-color)}.notification-title{font-weight:600;font-size:var(--font-size-base);color:var(--text-primary)}.notification-mark-read{font-size:11px;color:var(--accent-color);background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:3px;white-space:nowrap}.notification-mark-read:hover{background:var(--bg-hover)}.notification-list{flex:1;overflow-y:auto;padding:4px 0}.notification-item{padding:8px 14px;font-size:var(--font-size-sm);transition:background .08s ease;cursor:default}.notification-item:hover{background:var(--bg-hover)}.notification-item-content{display:flex;flex-direction:column;gap:2px}.notification-text{line-height:1.4;color:var(--text-primary);word-break:break-word}.notification-text strong{font-weight:600}.notification-file{color:var(--accent-color);font-weight:500;word-break:break-all}.notification-time{font-size:11px;color:var(--text-muted);margin-top:1px}.notification-empty{padding:24px 14px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.comments-panel{width:340px;min-width:260px;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:var(--font-size-base)}.panel-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.panel-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-secondary);padding:0 4px;line-height:1;border-radius:3px}.panel-close:hover{background:var(--bg-hover);color:var(--text-primary)}.comments-list{flex:1;overflow-y:auto;padding:8px 0}.comments-empty{padding:24px 14px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.comment-item{padding:8px 14px;border-bottom:1px solid var(--row-border)}.comment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.comment-author{font-weight:600;font-size:var(--font-size-sm);color:var(--accent-color)}.comment-time{font-size:11px;color:var(--text-muted)}.comment-content{font-size:var(--font-size-base);line-height:1.4;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.comment-input-area{padding:10px 14px;border-top:1px solid var(--border-color);display:flex;flex-direction:column}.activity-feed{width:340px;min-width:260px;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.activity-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border-color);font-weight:600;font-size:var(--font-size-base)}.activity-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-list{flex:1;overflow-y:auto;padding:4px 0}.activity-empty{padding:24px 14px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.activity-group-label{padding:6px 14px 4px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.activity-item{display:flex;align-items:flex-start;gap:8px;padding:8px 14px;border-bottom:1px solid var(--row-border);font-size:var(--font-size-sm)}.activity-icon{flex-shrink:0;width:20px;text-align:center;font-size:14px;margin-top:1px}.activity-text{flex:1;line-height:1.4}.activity-file{color:var(--accent-color);font-weight:500}.activity-time{font-size:11px;color:var(--text-muted);margin-left:4px}.favorite-star{cursor:pointer;font-size:14px;color:var(--text-muted);flex-shrink:0;opacity:.3;transition:opacity .15s ease,color .15s ease}.file-list-row:hover .favorite-star,.favorite-star.active{opacity:1}.favorite-star.active{color:#f5a623}.favorite-star:hover{color:#f5a623;opacity:1}.trash-banner{background:var(--banner-bg);border-bottom:1px solid var(--banner-border);padding:8px 16px;font-size:var(--font-size-sm);color:var(--banner-text);display:flex;align-items:center;gap:8px}.folder-upload-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 32px #00000040;width:520px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:modal-card-in .2s ease}.folder-upload-header{padding:16px 20px 12px;border-bottom:1px solid var(--border-color)}.folder-upload-header .modal-title{margin-bottom:4px}.folder-upload-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.folder-upload-toolbar{display:flex;align-items:center;gap:8px;padding:8px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary)}.folder-upload-toolbar-btn{padding:3px 10px;font-size:11px;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);color:var(--text-primary)}.folder-upload-toolbar-btn:hover{background:var(--bg-hover)}.folder-upload-selection-info{font-size:11px;color:var(--text-secondary);margin-left:auto}.folder-upload-tree{flex:1;overflow-y:auto;min-height:200px;max-height:50vh;padding:4px 0}.folder-upload-empty{padding:24px 20px;text-align:center;color:var(--text-muted);font-size:var(--font-size-sm)}.folder-tree-row{display:flex;align-items:center;gap:4px;padding:3px 8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--font-size-base);transition:background .08s ease}.folder-tree-row:hover{background:var(--bg-hover)}.folder-tree-expand{width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--text-secondary);flex-shrink:0;cursor:pointer;border-radius:3px}.folder-tree-expand:hover{background:var(--bg-selected)}.custom-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:16px;height:16px;border:1.5px solid var(--text-muted);border-radius:3px;background:transparent;cursor:pointer;flex-shrink:0;position:relative;transition:background .15s,border-color .15s}.custom-checkbox:checked{background:var(--accent-color);border-color:var(--accent-color)}.custom-checkbox:checked:after{content:"";position:absolute;left:4.5px;top:1.5px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.custom-checkbox:hover:not(:disabled){border-color:var(--accent-color)}.custom-checkbox:disabled{opacity:.5;cursor:default}.folder-tree-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:14px;height:14px;flex-shrink:0;cursor:pointer;border:1.5px solid var(--text-muted);border-radius:3px;background:transparent;position:relative;transition:background .15s,border-color .15s}.folder-tree-checkbox:checked{background:var(--accent-color);border-color:var(--accent-color)}.folder-tree-checkbox:checked:after{content:"";position:absolute;left:3.5px;top:.5px;width:4px;height:7px;border:solid #fff;border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}.folder-tree-checkbox:hover{border-color:var(--accent-color)}.folder-tree-icon{display:flex;align-items:center;flex-shrink:0;color:var(--text-secondary)}.folder-tree-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.folder-tree-size{font-size:11px;color:var(--text-muted);flex-shrink:0;margin-left:8px}.folder-upload-footer{padding:12px 20px;display:flex;justify-content:flex-end;gap:8px;border-top:1px solid var(--border-color)}.folder-upload-btn{padding:6px 18px;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary)}.folder-upload-btn:hover{background:var(--bg-hover)}.folder-upload-btn.primary{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.folder-upload-btn.primary:hover{opacity:.9}.folder-upload-btn.primary:disabled{opacity:.5;cursor:default}.folder-diff-summary-bar{display:flex;align-items:center;gap:14px;padding:8px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);font-size:12px;color:var(--text-secondary)}.folder-diff-stat{display:flex;align-items:center;gap:5px}.folder-diff-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.folder-diff-status{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:1px 6px;border-radius:3px;color:#fff;flex-shrink:0;margin-left:auto}.cloudverest-logo-graphic,.cloudverest-logo-text{display:block}[data-theme=dark] .cloudverest-logo-graphic{filter:brightness(1.2) drop-shadow(0 0 8px rgba(255,255,255,.3))}[data-theme=dark] .cloudverest-logo-text{filter:brightness(0) invert(1) opacity(.95)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:99}.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:1px solid transparent;border-radius:3px;background:transparent;color:var(--text-primary);cursor:pointer;flex-shrink:0}.mobile-menu-btn:hover{background:var(--bg-hover);border-color:var(--border-color)}.mobile-menu-btn svg{width:20px;height:20px}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes modal-card-in{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes context-menu-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes panel-slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes drop-zone-pulse{0%,to{border-color:var(--accent-color);background:#0078d41a}50%{border-color:#0078d466;background:#0078d40d}}@keyframes boot-pulse{0%,to{opacity:.9;transform:scale(1)}50%{opacity:.5;transform:scale(.97)}}@keyframes progress-shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:100;transform:translate(-100%);transition:transform .2s ease;box-shadow:none}.sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 16px #0003}.sidebar-overlay.visible{display:block}.mobile-menu-btn{display:flex}.toolbar-btn .btn-label{display:none}.toolbar-btn{flex-shrink:0}.toolbar-user{display:none}.toolbar-separator{margin:0 2px;flex-shrink:0}.app-toolbar{gap:1px;padding:3px 4px;overflow-x:auto;-webkit-overflow-scrolling:touch}.toolbar-spacer{flex-shrink:1;min-width:0}.toolbar-search{max-width:140px;flex-shrink:0}.toolbar-filter-select{max-width:90px;flex-shrink:0}.file-list-scroll-inner{min-width:0!important}.file-list-header,.file-list-row{grid-template-columns:1fr 70px 100px!important}.file-list-header>*,.file-list-row>*{order:unset!important}.file-list-header>*:nth-child(n+4),.file-list-row>*:nth-child(n+4){display:none!important}.file-list-row{min-height:40px}.file-compact-row{min-height:40px;padding:6px 12px}.right-column,.right-column-resize-handle{display:none}.version-panel,.preview-panel,.comments-panel,.activity-feed,.ws-panel:not(.ws-panel-embedded){position:fixed;right:0;top:40px;bottom:0;width:100%;max-width:400px;z-index:90;box-shadow:-4px 0 16px #00000026}.modal{min-width:unset;width:90vw;max-width:600px}.modal-dialog{min-width:unset;width:90vw;max-width:400px}.upload-panel{width:calc(100vw - 32px);max-width:360px;right:16px}.download-panel{width:calc(100vw - 32px);max-width:380px;right:16px}.notification-dropdown{width:calc(100vw - 32px);max-width:320px}.context-menu{max-width:calc(100vw - 32px)}.breadcrumbs{overflow-x:auto;-webkit-overflow-scrolling:touch}.breadcrumbs-bar{flex-shrink:0;min-width:max-content}.status-bar{gap:8px;font-size:10px}}@media(max-width:480px){.file-list-scroll-inner{min-width:0!important}.file-list-header,.file-list-row{grid-template-columns:1fr 60px!important}.file-list-header>*,.file-list-row>*{order:unset!important}.file-list-header>*:nth-child(n+3),.file-list-row>*:nth-child(n+3){display:none!important}.file-list-row{padding:6px 8px;min-height:44px}.file-list-header{padding:6px 8px}.file-compact-row{min-height:44px;padding:8px}.file-grid-item{padding:14px 10px 10px}.app-toolbar{padding:2px 4px;min-height:38px}.toolbar-title img.cloudverest-logo-text{display:none}.toolbar-search{max-width:100px;min-width:0}.toolbar-search-input{min-width:40px}.toolbar-filter-select{display:none}.auth-card{width:90vw;padding:24px 20px}.version-panel,.preview-panel,.comments-panel,.activity-feed,.ws-panel{max-width:100%}.folder-upload-modal{width:95vw}.sidebar{width:min(260px,85vw);min-width:min(260px,85vw);max-width:min(260px,85vw)}}.local-file-tree{padding:2px 0}.local-tree-item{display:flex;align-items:center;gap:4px;padding:2px 8px;cursor:pointer;font-size:12px;min-height:24px;-webkit-user-select:none;user-select:none;white-space:nowrap;overflow:hidden}.local-tree-item:hover{background:var(--bg-hover)}.local-tree-chevron{display:flex;align-items:center;justify-content:center;width:14px;height:14px;flex-shrink:0;transition:transform .15s ease;color:var(--text-muted);cursor:pointer}.local-tree-chevron-spacer{width:14px;flex-shrink:0}.local-tree-icon{display:flex;align-items:center;flex-shrink:0}.local-tree-name{overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.local-tree-status{width:16px;height:16px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-left:auto}.local-tree-status.new{background:#e8f5e9;color:#2e7d32}.local-tree-status.modified{background:#fdf0d5;color:#b27d00}.local-tree-lock{display:flex;align-items:center;flex-shrink:0;margin-left:2px}.local-tree-lock.self{color:var(--accent-color, #1976d2)}.local-tree-lock.other{color:var(--danger-color, #c62828)}.local-tree-loading{font-size:11px;color:var(--text-muted);font-style:italic;padding:4px 8px}.local-tree-children{display:grid;transition:grid-template-rows .15s ease}[data-theme=dark] .local-tree-status.new{background:#2e7d3233;color:#66bb6a}[data-theme=dark] .local-tree-status.modified{background:#b27d0033;color:#ffb74d}.branch-selector{display:inline-flex}.branch-selector-btn.toolbar-btn{flex-direction:row;min-width:80px;max-width:180px;padding:4px 6px 4px 10px;gap:0}.branch-selector-main{display:flex;flex-direction:column;align-items:center;gap:1px;flex:1;min-width:0}.branch-selector-main .btn-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.branch-selector-chevron{display:flex;align-items:center;justify-content:center;opacity:.5;width:16px;flex-shrink:0;margin-left:2px;border-left:1px solid var(--border-color);padding-left:4px;align-self:stretch}.branch-selector-btn.toolbar-btn:hover .branch-selector-chevron{opacity:.8}.branch-selector-dropdown{min-width:240px;max-width:320px;max-height:360px;overflow-y:auto;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 32px #0000002e;padding:4px 0}.branch-selector-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding:8px 12px 4px}.branch-selector-item{display:flex;align-items:center;gap:6px;width:100%;padding:6px 12px;border:none;background:none;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-base, 13px);cursor:pointer;text-align:left}.branch-selector-item:hover{background:var(--hover-bg, rgba(128,128,128,.08))}.branch-selector-item-active{font-weight:600}.branch-selector-item-inactive{opacity:.55}.branch-selector-item-check{width:18px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent-color)}.branch-selector-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.branch-selector-default-label{font-size:11px;color:var(--text-secondary);margin-left:4px}.branch-selector-file-count{font-size:11px;color:var(--text-secondary);flex-shrink:0}.branch-selector-status-label{font-size:10px;padding:1px 6px;border-radius:3px;background:#8080801f;color:var(--text-secondary);flex-shrink:0}.branch-selector-divider{height:1px;background:var(--border-color);margin:4px 0}.branch-selector-manage{color:var(--accent-color);font-weight:500}.branch-selector-create-form{display:flex;gap:4px;padding:6px 12px;align-items:center}.branch-selector-create-input{flex:1;padding:4px 8px;border:1px solid var(--border-color);border-radius:3px;background:var(--bg-secondary, var(--bg-primary));color:var(--text-primary);font-size:12px;font-family:var(--font-family);min-width:0}.branch-selector-create-input:focus{outline:none;border-color:var(--accent-color)}.branch-selector-create-btn{padding:4px 10px;border:1px solid var(--accent-color);border-radius:3px;background:var(--accent-color);color:#fff;font-size:11px;cursor:pointer;white-space:nowrap}.branch-selector-create-btn:disabled{opacity:.5;cursor:not-allowed}.toast-container{position:fixed;bottom:24px;left:24px;z-index:10000;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:380px}.toast{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:8px;font-size:13px;line-height:1.4;pointer-events:auto;cursor:pointer;animation:toast-in .25s ease forwards;box-shadow:0 4px 16px #00000040;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:opacity .2s ease,transform .2s ease}.toast:hover{opacity:.85}.toast-success{background:#1a3a2a;border:1px solid #2d6b45;color:#a3e4b8}.toast-error{background:#3a1a1a;border:1px solid #6b2d2d;color:#e4a3a3}.toast-info{background:#1a2a3a;border:1px solid #2d456b;color:#a3c4e4}.toast-icon{font-size:15px;font-weight:700;flex-shrink:0}.toast-message{flex:1;min-width:0}.toast-action{background:none;border:1px solid currentColor;border-radius:4px;padding:2px 10px;font-size:12px;cursor:pointer;color:inherit;white-space:nowrap;opacity:.85;transition:opacity .15s}.toast-action:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:480px){.toast-container{left:12px;right:12px;bottom:12px;max-width:none}}.skeleton-row{display:flex;align-items:center;gap:12px;padding:8px 16px;height:36px}.skeleton-bone{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-hover) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite;border-radius:4px}.skeleton-icon{width:20px;height:20px;border-radius:4px;flex-shrink:0}.skeleton-name{height:14px;flex:1}.skeleton-meta{height:12px;width:70px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.review-layout{display:flex;flex:1;min-width:0;height:100%;background:var(--bg-primary);overflow:hidden}.review-main-column{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.review-center-message{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:8px;color:var(--text-muted);font-size:13px}.review-media-strip{display:flex;align-items:center;gap:8px;padding:8px 12px;height:96px;min-height:96px;overflow-x:auto;overflow-y:hidden;background:transparent;flex-shrink:0;scrollbar-width:thin;scroll-behavior:smooth}.review-media-strip::-webkit-scrollbar{height:4px}.review-media-strip::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.review-media-thumb{position:relative;width:120px;min-width:120px;height:80px;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid transparent;background:#0a0a0a;transition:border-color .15s,transform .15s,box-shadow .15s;display:flex;flex-direction:column}.review-media-thumb:hover{border-color:var(--border-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.review-media-thumb:active{transform:translateY(0) scale(.97)}.review-media-thumb.active{border-color:var(--accent-color);box-shadow:0 0 0 1px var(--accent-color),0 4px 12px #4285f426}.review-media-thumb img{width:100%;height:60px;object-fit:cover;display:block}@keyframes reviewThumbShimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.review-media-thumb img{animation:none}.review-media-thumb-icon{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:12px;font-weight:600;background:var(--bg-tertiary, #1a1a1a)}.review-media-thumb-icon.video{color:var(--accent-color)}.review-media-thumb-icon.video svg{width:24px;height:24px}.review-media-thumb-label{padding:2px 6px;font-size:9px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:#0009;line-height:1.4}.review-media-thumb-badge{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center}.review-media-thumb-badge svg{width:10px;height:10px}.review-viewer{display:flex;flex-direction:column;flex:1;min-width:0;height:100%;background:var(--bg-primary);overflow:hidden}.review-viewer-body{display:flex;flex:1;overflow:hidden;min-height:0}.review-approval-bar{display:flex;align-items:center;gap:10px;padding:6px 12px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary, var(--bg-primary));flex-shrink:0}.review-approval-bar .review-version-label{font-size:12px;font-weight:600;color:var(--text-primary)}.review-approval-bar .review-status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.review-status-badge.approved{background:#1b5e2040;color:#4caf50}.review-status-badge.changes-requested{background:#b7141440;color:#ef5350}.review-status-badge.needs-review{background:#e6510040;color:#ff9800}.review-status-badge.none{background:var(--bg-tertiary, #333);color:var(--text-muted)}.review-approval-bar .review-approval-actions{display:flex;gap:6px;margin-left:auto}.review-approval-bar .review-close-btn{margin-left:8px;background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;font-size:16px;line-height:1}.review-approval-bar .review-close-btn:hover{color:var(--text-primary)}.review-approval-btn{padding:3px 10px;border-radius:4px;border:1px solid;font-size:11px;font-weight:600;cursor:pointer;transition:opacity .15s,transform .1s}.review-approval-btn:hover{opacity:.85}.review-approval-btn:active{transform:scale(.95)}.review-approval-btn.approve{background:#2e7d32;border-color:#2e7d32;color:#fff}.review-approval-btn.request-changes{background:#c62828;border-color:#c62828;color:#fff}.review-approval-btn.mark-review{background:#e65100;border-color:#e65100;color:#fff}.review-approval-btn.approve-conditions{background:#1b5e20;border-color:#1b5e20;color:#81c784}.review-approval-btn.clear-status{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.review-approval-comment-input{display:flex;gap:6px;align-items:center;margin-left:8px}.review-approval-comment-input input{padding:3px 8px;font-size:11px;border:1px solid var(--border-color);border-radius:3px;background:var(--input-bg, #1e1e1e);color:var(--text-primary);width:200px}.review-canvas-area{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;position:relative}.review-canvas-container{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#111}.review-canvas-container img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.review-canvas-container .review-fabric-overlay{position:absolute;top:0;left:0;pointer-events:none}.review-canvas-container .review-fabric-overlay.drawing{pointer-events:auto;cursor:crosshair}.review-fabric-overlay.drawing{cursor:crosshair}.review-toolbar{display:flex;align-items:center;gap:4px;padding:4px 8px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary, var(--bg-primary));flex-shrink:0}.review-toolbar button{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text-secondary);cursor:pointer;padding:0;transition:all .1s}.review-toolbar button:hover{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary)}.review-toolbar button.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.review-toolbar .toolbar-separator{width:1px;height:20px;background:var(--border-color);margin:0 4px}.review-toolbar .color-swatch{width:20px;height:20px;border-radius:50%;border:2px solid var(--border-color);cursor:pointer;padding:0;transition:border-color .1s}.review-toolbar .color-swatch:hover,.review-toolbar .color-swatch.active{border-color:var(--text-primary)}.review-annotation-marker{position:absolute;width:22px;height:22px;border-radius:50%;background:var(--accent-color);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transform:translate(-50%,-50%);border:2px solid #fff;box-shadow:0 1px 4px #0006;transition:transform .1s;z-index:10}.review-annotation-marker:hover,.review-annotation-marker.active{transform:translate(-50%,-50%) scale(1.2)}.review-annotation-marker.resolved{background:var(--text-muted);opacity:.6}.review-comments-panel{width:320px;min-width:280px;border-left:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.review-comments-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-color);flex-shrink:0}.review-comments-header h3{font-size:12px;font-weight:600;margin:0;color:var(--text-primary)}.review-comments-filters{display:flex;gap:4px}.review-comments-filters button{padding:2px 8px;font-size:10px;border:1px solid var(--border-color);border-radius:10px;background:transparent;color:var(--text-secondary);cursor:pointer}.review-comments-filters button.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.review-comments-list{flex:1;overflow-y:auto;padding:8px}.review-comments-empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:40px 16px;color:var(--text-muted);font-size:12px}.review-comments-list{scroll-behavior:smooth}.review-comments-filters button{transition:all .15s}@keyframes reviewThreadPulse{0%{box-shadow:0 0 #4285f466}70%{box-shadow:0 0 0 6px #4285f400}to{box-shadow:0 0 #4285f400}}.review-thread{margin-bottom:12px;border:1px solid var(--border-color);border-radius:6px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.review-thread:hover{border-color:var(--text-muted)}.review-thread.active{border-color:var(--accent-color);animation:reviewThreadPulse .6s ease-out}.review-thread.resolved-thread{opacity:.5}.review-thread.resolved-thread:hover{opacity:1}.review-thread.addressed-thread{opacity:.7;border-color:#42a5f54d}.review-thread.addressed-thread:hover{opacity:1}.review-thread-header{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:var(--bg-secondary, var(--bg-primary));cursor:pointer;transition:background .15s}.review-thread-header:hover{background:var(--bg-tertiary, #222)}.review-thread-avatar{width:24px;height:24px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}.review-thread-body{flex:1;min-width:0}.review-thread-meta{display:flex;align-items:center;gap:6px;margin-bottom:2px}.review-thread-author{font-size:11px;font-weight:600;color:var(--text-primary)}.review-thread-time{font-size:10px;color:var(--text-muted)}.review-thread-timecode{font-size:10px;font-family:monospace;background:#1565c040;color:#42a5f5;padding:1px 5px;border-radius:3px;cursor:pointer}.review-thread-timecode:hover{background:#1565c080}.review-thread-content{font-size:12px;color:var(--text-primary);line-height:1.4;word-break:break-word}.review-thread-annotation-thumb{margin-top:6px;border-radius:4px;overflow:hidden;border:1px solid var(--border-color);max-width:180px;opacity:.85;transition:opacity .15s}.review-thread-annotation-thumb:hover{opacity:1}.review-thread-annotation-thumb img{display:block;width:100%;height:auto}.review-reply-count{display:flex;align-items:center;gap:5px;padding:2px 10px 2px 42px;font-size:10px;color:var(--text-muted);border-top:1px solid var(--border-color)}.review-thread-actions{display:flex;gap:4px;padding:4px 10px 6px}.review-thread-actions button{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-muted);background:none;border:1px solid transparent;border-radius:3px;cursor:pointer;padding:3px 8px;transition:all .15s}.review-thread-actions button:hover{color:var(--text-primary);background:var(--bg-tertiary, #222);border-color:var(--border-color)}.review-unresolved-count{font-weight:500;color:#ff9800;font-size:10px;background:#ff98001f;padding:1px 6px;border-radius:8px;margin-left:8px}.review-shortcut-hint{font-size:10px;color:var(--text-muted);opacity:.6;font-family:SF Mono,Cascadia Mono,Consolas,monospace}.review-reply{display:flex;gap:8px;padding:6px 10px 6px 32px;border-top:1px solid var(--border-color)}.review-reply-input{display:flex;gap:6px;padding:6px 10px;border-top:1px solid var(--border-color)}.review-reply-input input{flex:1;padding:4px 8px;font-size:11px;border:1px solid var(--border-color);border-radius:3px;background:var(--input-bg, #1e1e1e);color:var(--text-primary)}.review-reply-input button{padding:4px 10px;font-size:11px;background:var(--accent-color);color:#fff;border:none;border-radius:3px;cursor:pointer;transition:opacity .15s,transform .1s}.review-reply-input button:hover{opacity:.9}.review-reply-input button:active{transform:scale(.95)}.review-reply-input button:disabled{opacity:.4;cursor:default;transform:none}.review-reply-input input:focus{outline:none;border-color:var(--accent-color)}.review-new-comment{padding:8px;border-top:1px solid var(--border-color);flex-shrink:0}.review-new-comment textarea{width:100%;padding:6px 8px;font-size:12px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg, #1e1e1e);color:var(--text-primary);resize:none;min-height:60px;font-family:inherit;box-sizing:border-box}.review-new-comment textarea:focus{outline:none;border-color:var(--accent-color)}.review-new-comment-actions{display:flex;justify-content:flex-end;gap:6px;margin-top:4px}.review-new-comment-actions button{padding:4px 12px;font-size:11px;border-radius:3px;cursor:pointer;border:none}.review-new-comment-actions .review-send-btn{background:var(--accent-color);color:#fff}.review-new-comment-actions .review-send-btn:disabled{opacity:.5;cursor:default}.review-resolved-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;background:#2e7d3240;color:#4caf50}.review-addressed-badge{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:3px;font-size:10px;font-weight:600;background:#1565c040;color:#42a5f5}.review-status-badge.approved_with_conditions{background:#1b5e2040;color:#81c784}.review-video-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.review-video-wrapper{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden}.review-video-wrapper video{max-width:100%;max-height:100%;cursor:pointer;transition:opacity .15s}.review-layout:fullscreen{background:#000}.review-layout:fullscreen .review-approval-bar{display:none}.review-layout:fullscreen .review-media-strip-container{display:none}.review-layout:fullscreen .review-main-column{flex:1}.review-layout:fullscreen .review-video-container{position:relative}.review-layout:fullscreen .review-video-wrapper{position:absolute;top:0;right:0;bottom:0;left:0}.review-layout:fullscreen .review-video-wrapper>video{width:100%;height:100%;max-width:none;max-height:none;object-fit:contain}.review-layout:fullscreen .review-compare-pane video{width:100%;height:100%;object-fit:contain}.review-layout:fullscreen .compare-wipe-container,.review-layout:fullscreen .compare-ab-container{width:100%;height:100%}.review-layout:fullscreen .review-compare-split{width:100%;height:100%}.review-layout:fullscreen .review-scrubber-area{position:absolute;bottom:42px;left:0;right:0;z-index:10;background:linear-gradient(transparent,#000000d9);border-top:none;padding:20px 16px 4px}.review-layout:fullscreen .review-video-controls{position:absolute;bottom:0;left:0;right:0;z-index:10;background:#000000d9}.review-layout:fullscreen .review-right-column{position:absolute;right:0;top:0;bottom:0;width:320px;max-width:40vw;z-index:20;box-shadow:-4px 0 24px #0009;transition:transform .25s ease;overflow:hidden;background:var(--bg-primary)}.review-layout:fullscreen .review-right-column.fs-hidden{transform:translate(100%);pointer-events:none}.review-scrubber-area{flex-shrink:0;padding:0 10px;background:var(--bg-secondary, var(--bg-primary));border-top:1px solid var(--border-color)}.review-scrubber-track{position:relative;height:36px;display:flex;align-items:center;cursor:pointer}.review-scrubber-track:before{content:"";position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);height:5px;background:var(--border-color);border-radius:3px;pointer-events:none;z-index:1;transition:height .15s ease}.review-scrubber-buffered{position:absolute;left:0;top:50%;transform:translateY(-50%);height:5px;background:#ffffff2e;border-radius:3px 0 0 3px;pointer-events:none;z-index:2;transition:width .3s ease,height .15s ease}.review-scrubber-progress{position:absolute;left:0;top:50%;transform:translateY(-50%);height:5px;background:var(--accent-color);border-radius:3px 0 0 3px;pointer-events:none;z-index:3;transition:height .15s ease}.review-scrubber-track:hover:before,.review-scrubber-track:hover .review-scrubber-progress,.review-scrubber-track:hover .review-scrubber-buffered{height:8px}.review-scrubber-track:hover input[type=range]{height:8px}.review-scrubber-track input[type=range]{width:100%;height:5px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border-radius:3px;outline:none;cursor:pointer;position:relative;z-index:4;margin:0;transition:height .15s ease}.review-scrubber-track input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-color);cursor:pointer;box-shadow:0 0 0 2px #0000004d,0 2px 6px #0000004d;transition:transform .15s}.review-scrubber-track:hover input[type=range]::-webkit-slider-thumb{transform:scale(1.25)}.review-scrubber-track input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-color);border:none;cursor:pointer;box-shadow:0 0 0 2px #0000004d,0 2px 6px #0000004d;transition:transform .15s}.review-scrubber-track:hover input[type=range]::-moz-range-thumb{transform:scale(1.25)}.review-scrubber-tooltip{position:absolute;bottom:100%;margin-bottom:8px;transform:translate(-50%);background:#000000e6;color:#fff;font-size:11px;font-family:SF Mono,Cascadia Mono,Consolas,monospace;padding:3px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:10;display:flex;flex-direction:column;align-items:center;gap:2px}.review-sprite-preview{border-radius:2px;background-repeat:no-repeat}.review-scrubber-tooltip-time{padding:0 5px 1px}.review-waveform-canvas{width:100%;height:16px;display:block;margin-top:-2px;cursor:pointer}.review-safe-area-overlays{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:6}.safe-area-rect{position:absolute;border:1px solid rgba(255,255,255,.4);border-radius:2px}.safe-area-title{top:10%;left:10%;right:10%;bottom:10%;border-color:#ffc83280}.safe-area-action{top:5%;left:5%;right:5%;bottom:5%;border-color:#32c8ff80}.safe-area-label{position:absolute;top:-1px;left:4px;font-size:9px;color:inherit;opacity:.6;text-transform:uppercase;letter-spacing:.5px}.safe-area-title .safe-area-label{color:#ffc832cc}.safe-area-action .safe-area-label{color:#32c8ffcc}.safe-area-crosshair{position:absolute;top:0;right:0;bottom:0;left:0}.safe-area-crosshair:before,.safe-area-crosshair:after{content:"";position:absolute;background:#ffffff4d}.safe-area-crosshair:before{left:50%;top:0;bottom:0;width:1px;transform:translate(-.5px)}.safe-area-crosshair:after{top:50%;left:0;right:0;height:1px;transform:translateY(-.5px)}.safe-area-thirds{position:absolute;top:0;right:0;bottom:0;left:0}.safe-area-thirds-h,.safe-area-thirds-v{position:absolute;background:#fff3}.safe-area-thirds-h{left:0;right:0;height:1px}.safe-area-thirds-v{top:0;bottom:0;width:1px}.safe-area-aspect-mask{position:absolute;top:0;right:0;bottom:0;left:0}.safe-area-aspect-mask:before,.safe-area-aspect-mask:after{content:"";position:absolute;left:0;right:0;background:#00000080;border:1px solid rgba(255,100,100,.3)}.safe-area-aspect-mask[style*="2.39"]:before{top:0;height:16.3%;border-top:none;border-left:none;border-right:none}.safe-area-aspect-mask[style*="2.39"]:after{bottom:0;height:16.3%;border-bottom:none;border-left:none;border-right:none}.safe-area-aspect-mask[style*="1.85"]:before{top:0;height:4.1%;border-top:none;border-left:none;border-right:none}.safe-area-aspect-mask[style*="1.85"]:after{bottom:0;height:4.1%;border-bottom:none;border-left:none;border-right:none}.safe-area-aspect-mask[style*="1.777"]:before,.safe-area-aspect-mask[style*="1.777"]:after{display:none}.safe-area-aspect-mask[style*="1.777"]{border:1px dashed rgba(255,100,100,.4)}.safe-area-aspect-mask[style*="1.333"]:before{top:0;bottom:0;height:auto;left:0;width:12.5%;border-left:none;border-top:none;border-bottom:none}.safe-area-aspect-mask[style*="1.333"]:after{top:0;bottom:0;height:auto;right:0;left:auto;width:12.5%;border-right:none;border-top:none;border-bottom:none}.review-guides-dropdown{position:relative}.review-guides-menu{position:absolute;bottom:100%;right:0;margin-bottom:6px;background:var(--bg-primary, #1e1e1e);border:1px solid var(--border-color);border-radius:8px;padding:6px 0;min-width:170px;box-shadow:0 8px 24px #00000080;z-index:20}.review-guides-menu-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:4px 12px 6px}.review-guides-menu-item{display:flex;align-items:center;gap:8px;padding:4px 12px;font-size:12px;color:var(--text-primary);cursor:pointer;transition:background .1s}.review-guides-menu-item:hover{background:var(--bg-tertiary, rgba(255, 255, 255, .05))}.review-guides-menu-item input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent-color, #3b82f6)}.review-video-controls{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:var(--bg-secondary, var(--bg-primary));flex-shrink:0}.review-controls-left{display:flex;align-items:center;gap:4px}.review-controls-right{display:flex;align-items:center;gap:8px}.review-ctrl-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;padding:0;transition:background .1s,color .1s}.review-ctrl-btn:hover{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary)}.review-ctrl-btn:active{transform:scale(.9)}.review-video-timecode{font-size:12px;font-family:SF Mono,Cascadia Mono,Consolas,monospace;color:var(--text-primary);min-width:90px;margin-left:6px}.review-video-duration{font-size:11px;font-family:SF Mono,Cascadia Mono,Consolas,monospace;color:var(--text-muted);margin-left:2px}.review-draw-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:12px;transition:all .15s}.review-draw-btn:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.review-draw-btn:active{transform:scale(.95)}.review-draw-btn span{font-size:11px;font-weight:500}.review-timeline-markers{position:relative;height:16px;margin:0;flex-shrink:0}.review-timeline-marker{position:absolute;top:2px;width:10px;height:10px;border-radius:50%;background:var(--accent-color);border:1px solid #fff;transform:translate(-50%);cursor:pointer;transition:transform .1s;z-index:5}.review-timeline-marker:hover{transform:translate(-50%) scale(1.3)}.review-timeline-marker-tooltip{position:absolute;bottom:18px;left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;font-size:10px;white-space:nowrap;pointer-events:none;z-index:20;box-shadow:0 2px 8px #0000004d}.review-inline-comment{position:absolute;z-index:20;background:var(--bg-primary);border:1px solid var(--accent-color);border-radius:6px;padding:8px;width:240px;box-shadow:0 4px 12px #0006}.review-inline-comment textarea{width:100%;padding:4px 6px;font-size:12px;border:1px solid var(--border-color);border-radius:3px;background:var(--input-bg, #1e1e1e);color:var(--text-primary);resize:none;min-height:40px;font-family:inherit;box-sizing:border-box}.review-inline-comment-actions{display:flex;justify-content:flex-end;gap:4px;margin-top:4px}.review-inline-comment-actions button{padding:3px 10px;font-size:11px;border-radius:3px;cursor:pointer;border:none}.review-annotation-input-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary, var(--bg-primary));border-top:1px solid var(--border-color);flex-shrink:0}.review-annotation-input-bar input[type=text]{flex:1;padding:7px 10px;font-size:12px;border:1px solid var(--border-color);border-radius:4px;background:var(--input-bg, #1e1e1e);color:var(--text-primary);font-family:inherit}.review-annotation-input-bar input[type=text]:focus{outline:none;border-color:var(--accent-color)}.review-annotation-save-btn{padding:6px 14px;font-size:12px;font-weight:600;background:var(--accent-color);color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap;transition:opacity .15s}.review-annotation-save-btn:hover{opacity:.9}.review-annotation-save-btn:disabled{opacity:.5;cursor:default}.review-annotation-cancel-btn{padding:6px 10px;font-size:12px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;white-space:nowrap}.review-annotation-cancel-btn:hover{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary)}.review-annotation-preview-overlay{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain;pointer-events:none;z-index:5;transition:opacity .2s ease}.review-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);cursor:pointer;z-index:4;opacity:0;transition:opacity .2s}.review-video-wrapper:hover .review-play-overlay{opacity:.85}.review-play-overlay:hover{opacity:1!important;transform:translate(-50%,-50%) scale(1.1)}@keyframes reviewActionFlash{0%{opacity:.8;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.review-action-flash{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:6;pointer-events:none;width:56px;height:56px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;color:#fff;animation:reviewActionFlash .5s ease-out forwards}.review-action-flash svg{width:24px;height:24px}.review-speed-btn{display:flex;align-items:center;justify-content:center;min-width:36px;height:26px;padding:0 6px;background:transparent;border:1px solid var(--border-color);border-radius:4px;color:var(--text-secondary);font-size:11px;font-weight:600;font-family:SF Mono,Cascadia Mono,Consolas,monospace;cursor:pointer;transition:all .15s}.review-speed-btn:hover{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary);border-color:var(--text-muted)}.review-speed-btn.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.review-volume-group{display:flex;align-items:center;gap:4px}.review-volume-slider{width:70px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-color);border-radius:2px;outline:none;cursor:pointer}.review-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-secondary);cursor:pointer;transition:background .1s}.review-volume-slider::-webkit-slider-thumb:hover{background:var(--text-primary)}.review-volume-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--text-secondary);border:none;cursor:pointer}.review-separator{width:1px;height:20px;background:var(--border-color);margin:0 6px;flex-shrink:0}.review-video-wrapper.comparing{flex-direction:row}.review-compare-split{display:flex;width:100%;height:100%;gap:0;min-height:0}.review-compare-pane{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-width:0;min-height:0}.review-compare-pane video{max-width:100%;max-height:100%;object-fit:contain;cursor:pointer}.review-compare-label{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:6;background:#000000b3;color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;pointer-events:none;white-space:nowrap}.review-compare-divider{width:2px;background:var(--accent-color);flex-shrink:0;position:relative}.review-compare-divider:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border-radius:50%;background:var(--accent-color);border:2px solid #000}.review-media-strip-container{flex-shrink:0;border-top:1px solid var(--border-color);background:var(--bg-secondary, var(--bg-primary))}.review-strip-tabs{display:flex;align-items:center;gap:2px;padding:4px 12px 0;border-bottom:1px solid var(--border-color)}.review-strip-tab{display:flex;align-items:center;gap:5px;padding:6px 12px;font-size:11px;font-weight:500;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s;margin-bottom:-1px}.review-strip-tab:hover{color:var(--text-primary)}.review-strip-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-color)}.review-strip-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 4px;font-size:10px;font-weight:600;background:var(--bg-tertiary, #333);color:var(--text-secondary);border-radius:8px}.review-strip-tab.active .review-strip-tab-count{background:var(--accent-color);color:#fff}.review-strip-tab.compare-active{color:#ff9800;background:#ff98001f;border-radius:4px;border-bottom-color:transparent;margin-left:auto;gap:4px;padding:4px 10px;font-weight:600}.review-strip-tab.compare-active:hover{background:#ff980033}.review-strip-empty{display:flex;align-items:center;justify-content:center;width:100%;color:var(--text-muted);font-size:12px;padding:16px}.review-version-thumb{position:relative;width:110px;min-width:110px;height:72px;border-radius:6px;overflow:hidden;cursor:pointer;border:2px solid var(--border-color);background:var(--bg-tertiary, #1a1a1a);transition:border-color .15s,transform .1s;display:flex;flex-direction:column;padding:6px 8px;gap:2px}.review-version-thumb:hover{border-color:var(--text-muted);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.review-version-thumb:active{transform:translateY(0) scale(.97)}.review-version-thumb.current{border-color:var(--accent-color);background:#4285f414}.review-version-thumb.comparing{border-color:#ff9800;box-shadow:0 0 0 1px #ff9800;background:#ff980014}.review-version-num{font-size:16px;font-weight:700;color:var(--text-primary);line-height:1.2}.review-version-info{display:flex;flex-direction:column;gap:1px}.review-version-uploader{font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.review-version-date{font-size:9px;color:var(--text-muted)}.review-version-status{position:absolute;top:4px;right:4px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px}.review-version-status.approved{background:#2e7d3240;color:#4caf50}.review-version-status.changes_requested{background:#c6282840;color:#ef5350}.review-version-status.needs_review{background:#e6510040;color:#ff9800}.review-version-badge{position:absolute;bottom:4px;right:4px;font-size:8px;font-weight:700;text-transform:uppercase;padding:1px 5px;border-radius:3px;background:var(--accent-color);color:#fff;letter-spacing:.3px}.review-version-badge.compare{background:#ff9800;color:#000}.review-version-compare-hint{position:absolute;bottom:4px;left:0;right:0;text-align:center;font-size:8px;color:var(--text-muted);opacity:0;transition:opacity .15s}.review-version-thumb:hover .review-version-compare-hint{opacity:1}.review-buffering-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:7;pointer-events:none}@keyframes reviewSpin{to{transform:rotate(360deg)}}.review-buffering-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:reviewSpin .8s linear infinite}.review-ctrl-btn.active{background:var(--accent-color);color:#fff}.review-toolbar .stroke-swatch{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:4px;background:transparent;cursor:pointer;padding:0;transition:all .1s}.review-toolbar .stroke-swatch:hover{background:var(--bg-tertiary, #2a2a2a)}.review-toolbar .stroke-swatch.active{border-color:var(--accent-color);background:var(--bg-tertiary, #2a2a2a)}.stroke-preview{display:block}.review-scrubber-track input[type=range]::-moz-range-track{background:var(--border-color);border-radius:2px;height:4px}.review-scrubber-track:hover input[type=range]::-moz-range-track{height:6px}.review-scrubber-track input[type=range]::-moz-range-progress{background:var(--accent-color);border-radius:2px;height:4px}.review-scrubber-track:hover input[type=range]::-moz-range-progress{height:6px}.review-reply-input textarea{flex:1;padding:6px 8px;font-size:11px;border:1px solid var(--border-color);border-radius:3px;background:var(--input-bg, #1e1e1e);color:var(--text-primary);resize:none;min-height:40px;font-family:inherit;box-sizing:border-box}.review-reply-input textarea:focus{outline:none;border-color:var(--accent-color)}.review-volume-slider::-moz-range-track{background:var(--border-color);border-radius:2px;height:4px}.review-volume-slider::-moz-range-progress{background:var(--text-secondary);border-radius:2px;height:4px}.review-canvas-area .review-scrubber-area,.review-canvas-area .review-video-controls{transition:opacity .35s ease,transform .35s ease}.review-canvas-area.controls-hidden .review-scrubber-area{opacity:0;pointer-events:none;transform:translateY(4px)}.review-canvas-area.controls-hidden .review-video-controls{opacity:0;pointer-events:none;transform:translateY(8px)}.review-canvas-area.controls-hidden .review-video-wrapper{cursor:none}.review-layout:fullscreen .review-canvas-area.controls-hidden .review-scrubber-area,.review-layout:fullscreen .review-canvas-area.controls-hidden .review-video-controls{opacity:0;pointer-events:none}.review-shortcuts-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;background:#0009;display:flex;align-items:center;justify-content:center;animation:reviewShortcutsFadeIn .15s ease}@keyframes reviewShortcutsFadeIn{0%{opacity:0}to{opacity:1}}.review-shortcuts-panel{background:var(--bg-primary, #1e1e1e);border:1px solid var(--border-color);border-radius:10px;width:420px;max-height:80vh;overflow-y:auto;box-shadow:0 16px 48px #00000080;animation:reviewShortcutsSlideIn .2s ease}@keyframes reviewShortcutsSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.review-shortcuts-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;border-bottom:1px solid var(--border-color)}.review-shortcuts-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.review-shortcuts-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:18px;border-radius:4px;transition:background .1s,color .1s}.review-shortcuts-close:hover{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary)}.review-shortcuts-body{padding:12px 18px 18px}.review-shortcuts-group{margin-bottom:16px}.review-shortcuts-group:last-child{margin-bottom:0}.review-shortcuts-group h4{margin:0 0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.review-shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.review-shortcut-keys{display:flex;align-items:center;gap:4px}.review-shortcut-keys kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 6px;background:var(--bg-tertiary, #2a2a2a);border:1px solid var(--border-color);border-radius:4px;font-size:11px;font-family:SF Mono,Cascadia Mono,Consolas,monospace;color:var(--text-primary);box-shadow:0 1px 0 var(--border-color)}.review-shortcut-or{font-size:10px;color:var(--text-muted)}.review-shortcut-desc{font-size:12px;color:var(--text-secondary)}.review-right-column{width:320px;min-width:280px;border-left:1px solid var(--border-color);display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden;flex-shrink:0}.review-right-column .review-comments-panel{width:auto;min-width:0;border-left:none;flex:1}.review-project-comments{flex:1;display:flex;flex-direction:column;overflow:hidden}.review-project-comments-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border-color);flex-shrink:0;font-size:12px;font-weight:600;color:var(--text-primary)}.review-project-comments-filters{display:flex;gap:4px}.review-project-comments-filters button{padding:2px 8px;font-size:10px;border:1px solid var(--border-color);border-radius:10px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s}.review-project-comments-filters button.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.review-project-comments-list{flex:1;overflow-y:auto;padding:4px 0;scrollbar-width:thin}.review-project-comments-empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:40px 16px;color:var(--text-muted);font-size:12px}.review-project-comment-group{margin-bottom:4px}.review-project-comment-file-header{display:flex;align-items:center;gap:6px;padding:6px 12px 4px;font-size:11px;font-weight:600;color:var(--text-secondary);position:sticky;top:0;background:var(--bg-primary);z-index:1}.review-project-comment-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.review-project-comment-file-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:14px;padding:0 4px;font-size:9px;font-weight:600;background:var(--bg-tertiary, #333);color:var(--text-muted);border-radius:7px}.review-project-comment-item{display:flex;gap:8px;padding:6px 12px;cursor:pointer;transition:background .1s}.review-project-comment-item:hover{background:var(--bg-tertiary, #222)}.review-project-comment-item.resolved{opacity:.5}.review-project-comment-item.resolved:hover{opacity:1}.review-project-comment-avatar{width:22px;height:22px;border-radius:50%;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;flex-shrink:0}.review-project-comment-body{flex:1;min-width:0}.review-project-comment-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:2px}.review-project-comment-author{font-size:11px;font-weight:600;color:var(--text-primary)}.review-project-comment-time{font-size:10px;color:var(--text-muted)}.review-project-comment-timecode{font-size:10px;font-family:monospace;background:#1565c040;color:#42a5f5;padding:1px 5px;border-radius:3px}.review-project-comment-version{font-size:9px;font-weight:600;background:var(--bg-tertiary, #333);color:var(--text-muted);padding:1px 5px;border-radius:3px}.review-project-comment-resolved{font-size:9px;font-weight:600;background:#2e7d3240;color:#4caf50;padding:1px 5px;border-radius:3px}.review-project-comment-content{font-size:12px;color:var(--text-primary);line-height:1.4;word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.review-post-error{padding:6px 12px;background:#ef535026;color:#ef5350;font-size:11px;text-align:center;cursor:pointer;flex-shrink:0;border-top:1px solid rgba(239,83,80,.3)}.review-toast{position:absolute;top:52px;left:50%;transform:translate(-50%);z-index:30;background:#000000d9;color:#fff;font-size:12px;padding:8px 16px;border-radius:6px;cursor:pointer;animation:reviewToastIn .2s ease;pointer-events:auto}@keyframes reviewToastIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.compare-mode-selector{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:15;display:flex;gap:2px;background:#000000bf;border-radius:6px;padding:3px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.compare-mode-selector button{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:500;color:#ffffffb3;background:transparent;border:none;border-radius:4px;cursor:pointer;transition:all .15s;white-space:nowrap}.compare-mode-selector button:hover{color:#fff;background:#ffffff1a}.compare-mode-selector button.active{color:#fff;background:var(--accent-color)}.compare-offset-control{display:flex;align-items:center;gap:0;margin-left:4px;border-left:1px solid rgba(255,255,255,.15);padding-left:4px}.compare-offset-control button{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;font-size:13px;font-weight:700;color:#fff9;background:transparent;border:none;border-radius:3px;cursor:pointer;transition:all .15s;line-height:1}.compare-offset-control button:hover{color:#fff;background:#ffffff26}.compare-offset-value{font-size:10px;font-weight:600;font-variant-numeric:tabular-nums;color:#ffffff80;min-width:28px;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:2px 0;border-radius:3px;transition:all .15s}.compare-offset-value:hover{color:#fff;background:#ffffff1a}.compare-offset-value.active{color:var(--accent-color)}.compare-wipe-container{position:relative;width:100%;height:100%;overflow:hidden;cursor:pointer}.compare-wipe-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;pointer-events:none}.compare-wipe-top{z-index:2}.compare-wipe-label{position:absolute;top:8px;z-index:6;background:#000000b3;color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;pointer-events:none;white-space:nowrap;transition:opacity .2s}.compare-wipe-label.left{left:12px}.compare-wipe-label.right{right:12px}.compare-wipe-divider{position:absolute;top:0;bottom:0;width:3px;background:#fff;z-index:10;cursor:ew-resize;transform:translate(-50%);touch-action:none}.compare-wipe-divider:before{content:"";position:absolute;top:0;bottom:0;left:-8px;right:-8px}.compare-wipe-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid rgba(0,0,0,.3);box-shadow:0 2px 8px #0006;display:flex;align-items:center;justify-content:center}.compare-wipe-handle:before,.compare-wipe-handle:after{content:"";position:absolute;width:2px;height:8px;background:#0006;border-radius:1px}.compare-wipe-handle:before{left:7px}.compare-wipe-handle:after{right:7px}.compare-ab-container{position:relative;width:100%;height:100%;overflow:hidden;cursor:pointer}.compare-ab-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:contain;transition:opacity .15s;pointer-events:none}.compare-ab-badge{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:6;background:#000000b3;color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;pointer-events:none;white-space:nowrap}.compare-ab-hint{position:absolute;bottom:12px;left:50%;transform:translate(-50%);z-index:6;background:#00000080;color:#fff9;font-size:10px;padding:2px 8px;border-radius:8px;pointer-events:none;opacity:0;transition:opacity .3s}.compare-ab-container:hover .compare-ab-hint{opacity:1}.review-in-marker,.review-out-marker{position:absolute;top:50%;width:3px;height:16px;transform:translate(-50%,-50%);z-index:5;pointer-events:none}.review-in-marker{background:#4caf50;border-radius:1px 0 0 1px}.review-in-marker:after{content:"";position:absolute;top:-3px;left:-2px;width:0;height:0;border-left:5px solid #4caf50;border-top:4px solid transparent;border-bottom:4px solid transparent}.review-out-marker{background:#ef5350;border-radius:0 1px 1px 0}.review-out-marker:after{content:"";position:absolute;top:-3px;right:-2px;width:0;height:0;border-right:5px solid #ef5350;border-top:4px solid transparent;border-bottom:4px solid transparent}.review-range-highlight{position:absolute;top:50%;height:6px;transform:translateY(-50%);background:#4caf5033;border-top:1px solid rgba(76,175,80,.4);border-bottom:1px solid rgba(76,175,80,.4);z-index:1;pointer-events:none}.review-timecode-burn-in{position:absolute;top:12px;left:12px;z-index:8;display:flex;flex-direction:column;gap:2px;padding:6px 10px;background:#000000b3;border-radius:4px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.review-timecode-burn-in-tc{font-size:20px;font-weight:700;font-family:SF Mono,Cascadia Mono,Consolas,monospace;color:#fff;letter-spacing:.5px}.review-timecode-burn-in-meta{font-size:10px;font-family:SF Mono,Cascadia Mono,Consolas,monospace;color:#fff9}.review-progress-badge{display:inline-flex;align-items:center;gap:6px;margin-left:8px;font-size:10px;font-weight:500;color:var(--text-muted)}.review-progress-bar{width:40px;height:4px;background:var(--border-color);border-radius:2px;overflow:hidden}.review-progress-bar-fill{height:100%;background:#4caf50;border-radius:2px;transition:width .3s ease}.mention-dropdown{position:absolute;bottom:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-primary, #1e1e1e);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 -4px 16px #0006;z-index:50;margin-bottom:4px}.mention-option{display:flex;align-items:center;gap:8px;padding:6px 10px;cursor:pointer;transition:background .1s}.mention-option:hover,.mention-option.selected{background:var(--bg-tertiary, #2a2a2a)}.mention-option-name{font-size:12px;font-weight:600;color:var(--text-primary)}.mention-option-email{font-size:10px;color:var(--text-muted)}.review-not-reviewable{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.review-not-reviewable-inner{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--text-muted);font-size:13px;text-align:center}.review-back-to-explorer{margin-top:8px;padding:6px 16px;font-size:12px;background:var(--bg-tertiary, #333);color:var(--text-primary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:background .1s}.review-back-to-explorer:hover{background:var(--bg-secondary, #444)}.review-pending-badge{display:flex;align-items:center;gap:6px;padding:6px 12px;margin:0 12px;background:#ffb43226;border:1px dashed rgba(255,180,50,.4);border-radius:4px;font-size:11px;color:#ffb432}.review-queue-bar{display:flex;align-items:center;gap:8px;padding:4px 12px;background:var(--bg-secondary, #1e1e1e);border-bottom:1px solid var(--border-color, #333);font-size:12px}.review-queue-bar .review-queue-name{font-weight:600;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.review-queue-bar .review-queue-position{color:var(--text-secondary, #888);font-size:11px;white-space:nowrap}.review-queue-nav-btn{background:none;border:1px solid var(--border-color, #444);color:var(--text-primary);border-radius:4px;padding:3px 10px;font-size:11px;cursor:pointer;transition:background .1s}.review-queue-nav-btn:hover{background:var(--bg-tertiary, #333)}.review-queue-nav-btn:disabled{opacity:.3;cursor:default}.review-media-format-badge{position:absolute;top:3px;right:3px;background:#000000b3;color:gold;font-size:8px;font-weight:700;padding:1px 4px;border-radius:2px;letter-spacing:.3px;text-transform:uppercase;pointer-events:none}.review-media-meta-badge{position:absolute;bottom:18px;left:3px;background:#000000b3;color:#fffc;font-size:8px;font-weight:500;padding:1px 4px;border-radius:2px;pointer-events:none;letter-spacing:.2px}.review-strip-group{display:flex;align-items:flex-end;gap:4px;position:relative;padding-left:4px}.review-strip-group+.review-strip-group{margin-left:8px;border-left:1px solid var(--border-color, #444);padding-left:12px}.review-strip-group-label{position:absolute;top:-14px;left:4px;font-size:9px;font-weight:600;color:var(--text-secondary, #888);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.review-file-info-chip{display:inline-flex;gap:6px;margin-left:8px;font-size:10px;color:var(--text-secondary, #888);font-weight:400}.review-file-info-chip span{background:#ffffff0f;padding:1px 5px;border-radius:3px}
