*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}.app-root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-content{flex:1;overflow:hidden}.nav-bar{display:flex;align-items:center;justify-content:space-between;height:44px;padding:0 16px;background:linear-gradient(135deg,#2e7d32,#388e3c,#43a047);color:#fff;flex-shrink:0;z-index:300}.nav-bar-left{display:flex;align-items:center;gap:4px}.nav-bar-title{font-size:15px;font-weight:600;margin-right:24px;letter-spacing:-.3px}.nav-bar-links{display:flex;gap:2px}.nav-tab{display:flex;align-items:center;padding:6px 14px;border-radius:6px;font-size:13px;font-weight:500;color:#ffffffbf;text-decoration:none;transition:all .15s ease}.nav-tab:hover{background:#ffffff1f;color:#fff}.nav-tab.active{background:#fff3;color:#fff}.nav-bar-right{display:flex;align-items:center;gap:8px}.nav-bar-email{font-size:12px;color:#ffffffb3;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-layout{display:flex;height:100%;overflow:hidden}.sidebar{width:320px;min-width:320px;height:100%;display:flex;flex-direction:column;background:#fff;border-right:1px solid #e0e0e0;overflow:hidden;transition:transform .3s ease;z-index:100}.sidebar.collapsed{transform:translate(-320px);min-width:0;width:0}.sidebar-toggle{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:200;background:#fff;border:1px solid #e0e0e0;border-left:none;border-radius:0 8px 8px 0;width:24px;height:48px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:2px 0 6px #00000014;transition:left .3s ease}.sidebar-toggle.open{left:320px}.main-area{flex:1;display:flex;overflow:hidden;min-width:0}.content-panel{flex:1;overflow-y:auto;padding:20px 24px;min-width:0;background:#fafafa}.links-panel{width:380px;min-width:380px;overflow-y:auto;border-left:1px solid #e0e0e0;background:#fff;padding:16px}.sidebar-header{padding:16px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.sidebar-header h1{margin:0;font-size:16px;font-weight:600;letter-spacing:-.3px}.sidebar-filters{padding:12px 16px;border-bottom:1px solid #e0e0e0;background:#fafafa}.sidebar-items{flex:1;overflow-y:auto;padding:4px 0}.sidebar-footer{padding:12px 16px;border-top:1px solid #e0e0e0;background:#fafafa}.item-btn{width:100%;text-align:left;border:none;background:transparent;padding:8px 16px;cursor:pointer;font-family:inherit;font-size:12px;line-height:1.4;border-bottom:1px solid #f0f0f0;transition:background .15s ease;display:flex;align-items:flex-start;gap:8px}.item-btn:hover{background:#f5f5f5}.item-btn.active{background:#e8f5e9;border-left:3px solid #4CAF50}.item-btn .status-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;margin-top:4px}.item-btn .status-dot.processed{background:#4caf50}.item-btn .status-dot.unprocessed{background:#ffc107}.item-btn .status-dot.syncing{background:#2196f3;animation:pulse-blue 1.5s ease-in-out infinite}.item-btn .status-dot.deployed{background:#9c27b0}@keyframes pulse-blue{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.item-btn .item-info{flex:1;min-width:0}.item-btn .item-path{font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-btn .item-counts{color:#888;font-size:11px;margin-top:2px}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;position:sticky;top:0;background:#fafafa;padding:8px 0;z-index:10}.content-section{margin-bottom:24px;background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 3px #0000000f}.content-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#333;padding-bottom:8px;border-bottom:2px solid #4CAF50}.content-body{line-height:1.7;font-size:14px;color:#333;word-break:break-word}.content-body table{width:100%;border-collapse:collapse;margin:12px 0}.content-body th,.content-body td{border:1px solid #e0e0e0;padding:8px 12px;text-align:left;font-size:13px}.content-body th{background:#f5f5f5;font-weight:600}.link-highlight{padding:1px 4px;border-radius:3px;cursor:pointer;text-decoration:none;transition:all .2s ease}.link-highlight:hover{filter:brightness(.9)}.link-highlight.original{background:#4caf5026;color:#2e7d32}.link-highlight.suggested{background:#ff980026;color:#e65100}.link-highlight.flash{animation:flashHighlight 1.5s ease}@keyframes flashHighlight{0%{box-shadow:0 0 #ffd700cc}30%{box-shadow:0 0 12px 4px #ffd70099;background:#ffff9980}to{box-shadow:none}}.links-header{font-size:15px;font-weight:600;margin-bottom:16px;color:#333}.links-section-title{font-size:13px;font-weight:600;color:#555;margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid #e0e0e0}.link-card{display:flex;align-items:flex-start;gap:8px;padding:8px;margin-bottom:4px;border-radius:6px;transition:background .15s ease;cursor:pointer}.link-card.original{background:#4caf5014}.link-card.original:hover{background:#4caf502e}.link-card.suggested{background:#ffc1071f}.link-card.suggested:hover{background:#ffc10740}.link-card .link-border{width:3px;min-height:100%;border-radius:2px;flex-shrink:0;align-self:stretch}.link-card .link-border.original{background:#4caf50}.link-card .link-border.suggested{background:#ff9800}.link-card .link-content{flex:1;min-width:0}.link-card .link-anchor{font-weight:500;font-size:13px;color:#333}.link-card .link-anchor .link-count{color:#888;font-weight:400}.link-card .link-url{font-size:11px;color:#888;word-break:break-all;margin-top:2px}.link-card .link-rationale{font-size:11px;color:#999;font-style:italic;margin-top:2px}.link-card .link-actions{display:flex;gap:4px;flex-shrink:0}.source-textarea{width:100%;min-height:300px;font-family:Fira Code,Consolas,monospace;font-size:13px;line-height:1.6;padding:12px;border:1px solid #e0e0e0;border-radius:6px;resize:vertical;outline:none;transition:border-color .2s}.source-textarea:focus{border-color:#4caf50;box-shadow:0 0 0 2px #4caf5026}.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:#666;gap:16px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:#999;text-align:center;gap:12px;height:100%}.empty-state svg{font-size:48px;opacity:.3}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}.edit-form-inline{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:12px;margin:4px 0 8px}.dashboard-layout{display:flex;flex-direction:column;height:100%;overflow:hidden;background:#f5f5f5}.dashboard-filters{padding:16px 24px;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.dashboard-filters-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.dashboard-summary{display:flex;gap:12px;padding:16px 24px;flex-shrink:0}.summary-card{flex:1;background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 1px 3px #0000000f;border-left:4px solid #e0e0e0}.summary-card.up-to-date{border-left-color:#4caf50}.summary-card.changed{border-left-color:#ff9800}.summary-card.missing{border-left-color:#9e9e9e}.summary-card.info{border-left-color:#2196f3}.summary-value{font-size:24px;font-weight:700;color:#333;line-height:1}.summary-label{font-size:12px;color:#888;margin-top:4px;font-weight:500}.dashboard-main{flex:1;display:flex;overflow:hidden;gap:0}.dashboard-table-section{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.dashboard-table-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 24px;background:#fff;border-bottom:1px solid #e0e0e0;flex-shrink:0}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px}.dashboard-table-container{flex:1;overflow-y:auto;padding:0 24px 24px}.dashboard-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000000f}.dashboard-table thead{position:sticky;top:0;z-index:5}.dashboard-table th{background:#fafafa;padding:10px 12px;font-size:12px;font-weight:600;color:#555;text-align:left;border-bottom:2px solid #e0e0e0;white-space:nowrap}.dashboard-table td{padding:8px 12px;font-size:13px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.dashboard-table tr:hover{background:#fafafa}.dashboard-table tr.selected{background:#2196f30a}.cell-path{font-weight:500;color:#333;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-name{color:#555;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-sections{max-width:220px}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:16px;color:#666;font-size:14px}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;color:#999;text-align:center;gap:12px;height:100%;font-size:14px}.dashboard-jobs-section{width:320px;min-width:320px;background:#fff;border-left:1px solid #e0e0e0;overflow-y:auto;padding:0;flex-shrink:0}.jobs-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;font-size:14px;font-weight:600;color:#333;border-bottom:1px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:5}.jobs-empty{padding:32px 16px;text-align:center;color:#999;font-size:13px}.job-card{padding:12px 16px;border-bottom:1px solid #f0f0f0;transition:background .15s}.job-card:hover{background:#fafafa}.job-card-header{display:flex;align-items:center;justify-content:space-between}.job-card-info{display:flex;align-items:center;gap:6px;flex-wrap:wrap;overflow:hidden;min-width:0}.job-type{font-size:12px;font-weight:600;color:#333;background:#f0f0f0;padding:2px 8px;border-radius:4px}.job-domain{font-size:12px;color:#666}.job-card-details{display:flex;align-items:center;gap:12px;margin-top:6px;font-size:12px;color:#888}.job-card-progress{margin-top:8px}.job-stage{font-size:11px;color:#666;font-style:italic}.job-pct{font-size:11px;color:#888;margin-top:2px;display:block}.job-card-result{margin-top:6px;font-size:12px;color:#4caf50}.job-failed{color:#f44336}.job-card-status{display:flex;align-items:center;gap:6px;margin-top:8px;font-size:11px;color:#888;text-transform:capitalize}.job-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.job-status-dot.submitted,.job-status-dot.queued{background:#2196f3}.job-status-dot.processing{background:#9c27b0;animation:pulse-blue 1.5s ease-in-out infinite}.job-status-dot.completed{background:#4caf50}.job-status-dot.failed{background:#f44336}.job-status-dot.cancelled{background:#9e9e9e}
