*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#f3f4f6;--color-surface:#fff;--color-border:#e5e7eb;--color-border-focus:#0078d4;--color-text:#111827;--color-text-muted:#6b7280;--color-primary:#0078d4;--color-primary-hover:#106ebe;--color-primary-text:#fff;--color-danger:#dc2626;--color-dirty:#fef3c7;--color-deleted:#fee2e2;--color-new:#ecfdf5;--color-selected-bg:#eff6ff;--color-selected-border:#0078d4;--nav-width:280px;--topbar-height:56px;--radius:6px;--shadow-sm:0 1px 2px #0000000f;--shadow:0 2px 8px #0000001a;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono:"Cascadia Code", "Fira Mono", monospace;font-size:14px}body{font-family:var(--font);background:var(--color-bg);color:var(--color-text);height:100vh;line-height:1.5;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex}.app-layout{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-body{flex:1;display:flex;overflow:hidden}.top-bar{height:var(--topbar-height);min-height:var(--topbar-height);color:#fff;box-shadow:var(--shadow);z-index:10;background:#1e1e2e;flex-shrink:0;align-items:center;gap:12px;padding:0 16px;display:flex;position:relative}.top-bar__brand{flex:1;align-items:center;gap:8px;display:flex}.top-bar__logo{flex-shrink:0;width:auto;height:38px;display:block}.top-bar__title{letter-spacing:.01em;font-size:15px;font-weight:600}.top-bar__actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.commit-progress{background:#fff3;height:3px;position:absolute;bottom:0;left:0;right:0}.commit-progress__bar{background:#60a5fa;height:100%;transition:width .2s}.queue-badge{color:#1a1a1a;white-space:nowrap;background:#f59e0b;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600}.user-info{border-left:1px solid #fff3;align-items:center;gap:8px;padding-left:12px;display:flex}.user-info__name{color:#ffffffd9;text-overflow:ellipsis;white-space:nowrap;max-width:160px;font-size:13px;overflow:hidden}.btn{border-radius:var(--radius);font-family:var(--font);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.btn--primary{background:var(--color-primary);color:var(--color-primary-text);border-color:var(--color-primary)}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--ghost{color:#ffffffd9;background:0 0;border-color:#ffffff4d}.btn--ghost:hover:not(:disabled){background:#ffffff1a}.tag-editor .btn--ghost,.nav-panel .btn--ghost,.commit-banner .btn--ghost{color:var(--color-text-muted);border-color:var(--color-border)}.tag-editor .btn--ghost:hover:not(:disabled),.nav-panel .btn--ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn--danger{color:var(--color-danger);background:0 0;border-color:#0000}.btn--danger:hover:not(:disabled){background:#fee2e2}.btn--sm{padding:4px 10px;font-size:12px}.btn--xs{padding:2px 6px;font-size:11px}.link-btn{color:var(--color-primary);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.nav-panel{width:var(--nav-width);background:var(--color-surface);border-right:none;flex-direction:column;flex-shrink:0;min-width:160px;display:flex;overflow:hidden}.resize-handle{cursor:col-resize;background:var(--color-border);flex-shrink:0;width:5px;transition:background .15s}.resize-handle:hover,.resize-handle:active{background:var(--color-primary)}.nav-panel--empty{justify-content:center;align-items:center}.nav-panel__hint{color:var(--color-text-muted);text-align:center;padding:24px 16px;font-size:13px}.nav-panel__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 12px 8px;display:flex}.nav-panel__heading{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:11px;font-weight:700}.nav-panel__loading{color:var(--color-text-muted);align-items:center;gap:8px;padding:12px;font-size:13px;display:flex}.nav-panel__error{color:var(--color-danger);background:#fee2e2;border-bottom:1px solid #fca5a5;padding:10px 12px;font-size:13px}.nav-list{outline:none;flex:1;padding:4px 0;overflow:hidden auto}.nav-list:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.nav-group{flex-direction:column;display:flex}.nav-item{cursor:pointer;width:100%;font-family:var(--font);color:var(--color-text);text-align:left;white-space:nowrap;background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:background .1s;display:flex;overflow:hidden}.nav-item:hover:not(:disabled){background:var(--color-bg)}.nav-item:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.nav-item--subscription{font-weight:500}.nav-item--rg{color:var(--color-text-muted);padding-left:32px;font-weight:400}.nav-item--selected{border-left-color:var(--color-selected-border);color:var(--color-primary);background:var(--color-selected-bg)!important}.nav-item--dirty .nav-item__name{font-style:italic}.nav-item--loading,.nav-item--error{color:var(--color-text-muted);cursor:default;padding-left:32px;font-size:12px}.nav-item--error{color:var(--color-danger)}.nav-item__chevron{color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:2px;font-size:9px;transition:transform .15s;display:inline-block}.nav-item__chevron--open{transform:rotate(90deg)}.nav-item__icon{flex-shrink:0;width:16px;height:16px;display:block}.nav-item__name{text-overflow:ellipsis;flex:1;overflow:hidden}.nav-item__location{color:var(--color-text-muted);flex-shrink:0;font-size:11px}.nav-item__dirty-dot{background:#f59e0b;border-radius:50%;flex-shrink:0;width:7px;height:7px}.nav-group__children{flex-direction:column;display:flex}.main-panel{background:var(--color-bg);flex:1;overflow-y:auto}.tag-editor{max-width:800px;padding:20px 24px}.tag-editor--empty{justify-content:center;align-items:center;max-width:none;height:100%;display:flex}.tag-editor__hint{color:var(--color-text-muted);text-align:center;max-width:320px;font-size:15px}.tag-editor__header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.tag-editor__title-block{flex-direction:column;gap:4px;min-width:0;display:flex}.tag-editor__type-badge{text-transform:uppercase;letter-spacing:.1em;color:var(--color-primary);background:#eff6ff;border-radius:4px;align-self:flex-start;padding:1px 6px;font-size:10px;font-weight:700}.tag-editor__title{text-overflow:ellipsis;font-size:18px;font-weight:600;overflow:hidden}.tag-editor__scope{font-family:var(--mono);color:var(--color-text-muted);text-overflow:ellipsis;font-size:11px;overflow:hidden}.tag-editor__actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.tag-editor__warning{border-radius:var(--radius);color:#92400e;background:#fef3c7;border:1px solid #f59e0b;margin-bottom:12px;padding:8px 12px;font-size:13px}.tag-editor__loading{color:var(--color-text-muted);align-items:center;gap:8px;padding:20px 0;font-size:13px;display:flex}.tag-editor__error{border-radius:var(--radius);color:var(--color-danger);background:#fee2e2;border:1px solid #fca5a5;align-items:center;gap:8px;padding:12px;font-size:13px;display:flex}.tag-editor__add-btn{margin-top:12px}.tag-table{border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius);width:100%;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);overflow:hidden}.tag-table__th{text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:8px 12px;font-size:11px;font-weight:700}.tag-table__th--actions{width:80px}.tag-table__td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:6px 12px}.tag-table__td--actions{justify-content:flex-end;align-items:center;gap:4px;display:flex}.tag-menu{display:inline-block;position:relative}.tag-menu__panel{z-index:1000;background:var(--color-surface);border:1px solid var(--color-border);border-radius:6px;flex-direction:column;min-width:260px;padding:4px;display:flex;box-shadow:0 6px 16px #0000002e}.tag-menu__item{text-align:left;cursor:pointer;color:var(--color-text);background:0 0;border:none;border-radius:4px;padding:8px 10px;font-size:13px}.tag-menu__item:hover:not(:disabled){background:var(--color-bg)}.tag-menu__item:disabled{opacity:.5;cursor:not-allowed}.tag-menu__item--danger{color:var(--color-danger)}.tag-row:last-child .tag-table__td{border-bottom:none}.tag-row:hover{background:#f9fafb}.tag-row--dirty{background:var(--color-dirty)!important}.tag-row--deleted{color:#9ca3af;text-decoration:line-through;background:var(--color-deleted)!important}.tag-row--new{background:var(--color-new)!important}.tag-cell{font-family:var(--mono);cursor:pointer;border-radius:3px;min-height:22px;padding:2px 4px;font-size:13px;display:block}.tag-cell:hover{background:#0000000a}.tag-cell:focus-visible{outline:2px solid var(--color-border-focus)}.tag-cell--empty{color:var(--color-text-muted);font-style:italic;font-family:var(--font)}.tag-input{font-family:var(--mono);border:1px solid var(--color-border-focus);background:var(--color-surface);width:100%;color:var(--color-text);border-radius:3px;outline:none;padding:3px 6px;font-size:13px;box-shadow:0 0 0 2px #0078d433}.commit-banner{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:flex-start;gap:12px;padding:10px 16px;font-size:13px;display:flex;position:relative}.commit-banner--success{color:#065f46;background:#ecfdf5}.commit-banner--partial{color:#92400e;background:#fef3c7}.commit-banner__summary{gap:12px;font-weight:600;display:flex}.commit-banner__ok{color:#065f46}.commit-banner__err{color:var(--color-danger)}.commit-banner__errors{color:var(--color-danger);flex:1;margin-top:4px;padding:0;font-size:12px;list-style:none}.commit-banner__close{position:absolute;top:8px;right:8px}.welcome-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f0f1999;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.welcome-card{background:var(--color-surface);text-align:center;max-width:420px;box-shadow:var(--shadow);border-radius:12px;flex-direction:column;align-items:center;gap:12px;padding:40px 48px;display:flex}.welcome-card__logo{width:48px;height:48px}.welcome-card__title{font-size:22px;font-weight:700}.welcome-card__desc{color:var(--color-text-muted);font-size:14px;line-height:1.6}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}.spinner--sm{width:12px;height:12px}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
