:root{color:#17202a;background:#f7f8fa;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0;background:#f7f8fa}button{font:inherit}.app-shell{max-width:1440px;margin:0 auto;padding:28px}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.app-header h1{margin:0;font-size:24px}.app-header p,.panel-header p,.muted{margin:4px 0 0;color:#667085}.summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;gap:10px;margin-bottom:12px}.summary-card,.panel{background:#fff;border:1px solid #dfe4ea;border-radius:8px}.summary-card{padding:12px;display:grid;gap:6px}.summary-card span{color:#697586;font-size:12px}.summary-card strong{font-size:18px}.primary-action{border:1px solid #cfd6df;border-radius:8px;background:#111827;color:#fff;padding:0 18px;cursor:pointer}.dashboard-grid{display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:2fr 1fr;gap:12px;height:calc(100vh - 200px);min-height:520px}.file-tree-panel{grid-row:1 / 3;grid-column:1;min-width:420px}.change-events-panel{grid-row:1;grid-column:2}.scan-log-panel{grid-row:2;grid-column:2}.panel{padding:14px;min-width:0;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;justify-content:space-between;margin-bottom:12px}.panel-header h2{margin:0;font-size:16px}.file-tree,.event-list{display:grid;gap:8px;flex:1;overflow-y:auto;min-height:0}.scan-log-content{flex:1;overflow-y:auto;min-height:0}.failure-list{display:grid;gap:8px}.tree-row{display:grid;grid-template-columns:18px 18px minmax(0,1fr) 32px;align-items:center;gap:6px;min-height:34px;border-radius:6px;color:#243040}.tree-row[data-selected=true]{background:#eef6ff;outline:1px solid #9bc7ff}@keyframes flash-highlight{0%,to{background:#fef3c7;outline:1px solid #fbbf24}50%{background:#fde68a;outline:1px solid #f59e0b}}.tree-row.flash{animation:flash-highlight .6s ease-in-out infinite}.tree-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-button{width:28px;height:28px;border:1px solid #d6dde6;border-radius:6px;background:#fff;cursor:pointer}.event-row{text-align:left;border:0;border-left:3px solid #99a3b3;border-radius:6px;padding:10px;background:#f6f8fa;display:grid;gap:4px;cursor:pointer}.event-row.added{border-left-color:#159a65;background:#f3fbf7}.event-row.modified{border-left-color:#3277d8;background:#f4f8ff}.event-row.deleted{border-left-color:#b42318;background:#fff6f5}.event-row[data-selected=true]{outline:1px solid #3277d8;background:#eef6ff}.event-row span,.event-row small,.failure-row span,.failure-row small{color:#667085}.log-block,.failure-row,.error-banner,.empty-state{border-radius:7px;background:#f6f8fa;padding:10px;margin-bottom:8px}.error-banner{background:#fff6f5;color:#b42318}.toast-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#111827;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;z-index:1000;cursor:pointer;animation:toast-in .2s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#f7f8fa}.login-card{background:#fff;border:1px solid #dfe4ea;border-radius:12px;padding:40px;width:360px;text-align:center}.login-card h1{margin:0 0 8px;font-size:24px}.login-card p{color:#667085;margin:0 0 24px}.login-card form{display:grid;gap:12px}.login-card input{padding:10px 14px;border:1px solid #dfe4ea;border-radius:8px;font-size:14px}.login-card button{padding:10px;border:none;border-radius:8px;background:#111827;color:#fff;font-size:14px;cursor:pointer}.login-card button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#b42318;font-size:13px}.tree-search{margin-bottom:12px;position:relative}.tree-search input{width:100%;padding:8px 12px 8px 32px;border:1px solid #dfe4ea;border-radius:6px;font-size:13px;box-sizing:border-box}.tree-search input:focus{outline:none;border-color:#9bc7ff}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#9ca3af;pointer-events:none}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #dfe4ea;border-radius:6px;box-shadow:0 4px 12px #00000014;max-height:240px;overflow-y:auto;z-index:50;list-style:none;margin:0;padding:4px 0}.search-dropdown li{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;color:#374151;min-width:0;overflow:hidden}.search-dropdown li:hover,.search-dropdown li.active{background:#f3f4f6}.search-dropdown li svg{flex-shrink:0;color:#9ca3af}.search-result-text{display:flex;flex-direction:column;min-width:0;overflow:hidden}.search-result-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px}.search-result-text mark{background:#fef3c7;color:#92400e;border-radius:2px;padding:0 1px}.search-result-path{font-size:11px;color:#9ca3af;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-dropdown.empty{padding:12px;text-align:center;color:#9ca3af;font-size:13px}.search-highlight{background:#fef3c7;color:#92400e;border-radius:2px;padding:0 1px}.tree-toggle{width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;color:#667085;padding:0}.tree-toggle:hover{color:#17202a}.tree-toggle-placeholder{width:18px}.tree-children{overflow:hidden}.tree-actions{display:flex;gap:8px}.text-button{font-size:12px;color:#667085;background:transparent;border:none;cursor:pointer;padding:2px 6px;border-radius:4px}.text-button:hover{color:#17202a;background:#f1f3f5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin 1s linear infinite}@media(max-width:1100px){.summary,.dashboard-grid{grid-template-columns:1fr;grid-template-rows:auto;height:auto}.file-tree-panel,.change-events-panel,.scan-log-panel{grid-row:auto;grid-column:auto;min-width:auto}}.event-filters{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:10px}.filter-tab{padding:4px 10px;border:1px solid #dfe4ea;border-radius:6px;background:#fff;font-size:12px;color:#667085;cursor:pointer}.filter-tab:hover{background:#f6f8fa;color:#374151}.filter-tab.active{background:#eef6ff;border-color:#3277d8;color:#3277d8}.custom-date-range{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:12px;color:#667085}.custom-date-range input[type=date]{padding:4px 8px;border:1px solid #dfe4ea;border-radius:6px;font-size:12px;font-family:inherit}.custom-date-range input[type=date]:focus{outline:none;border-color:#9bc7ff}.event-empty{text-align:center;padding:24px 12px;color:#9ca3af;font-size:13px}.event-error{padding:8px 12px;margin-bottom:8px;border-radius:6px;background:#fff6f5;color:#b42318;font-size:12px}.event-pagination{display:flex;align-items:center;justify-content:space-between;padding-top:10px;margin-top:4px;border-top:1px solid #f0f0f0}.page-btn{padding:4px 10px;border:1px solid #dfe4ea;border-radius:6px;background:#fff;font-size:12px;color:#374151;cursor:pointer}.page-btn:hover:not(:disabled){background:#f6f8fa}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-info{font-size:12px;color:#667085}
