*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{background:#fff;color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;min-height:100vh}.loading-container{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.spinner{animation:spin .6s linear infinite;border:4px solid #f0f0f0;height:40px;margin-bottom:20px;width:40px}.centered-loader-card{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;text-align:center}.btn{border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;font-size:14px;font-weight:600;overflow:hidden;padding:12px 24px;position:relative;transition:all .3s ease}.btn:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:hover:before{height:300px;width:300px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d}.btn-primary:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 6px 16px #667eea66}.btn-primary:active{box-shadow:0 2px 8px #667eea4d;transform:translateY(0)}.btn-primary:disabled,.btn.btn-primary:disabled{color:#fff!important;cursor:not-allowed!important;opacity:.6!important;pointer-events:none}.btn-primary:disabled,.btn-primary:disabled:hover,.btn.btn-primary:disabled,.btn.btn-primary:disabled:hover{background:linear-gradient(135deg,#9ca3af,#6b7280)!important;box-shadow:none!important;transform:none!important}.btn-primary:disabled:before,.btn.btn-primary:disabled:before{display:none!important}.btn-secondary{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);border:2px solid #d1d9e6;box-shadow:0 2px 4px #0000001a}.btn-secondary:hover{background:linear-gradient(135deg,#e8ecf1,#d1d9e6);border-color:#667eea;box-shadow:0 4px 12px #667eea33;color:#5568d3;transform:translateY(-2px)}.btn-secondary:active{box-shadow:0 2px 8px #667eea26;transform:translateY(0)}.btn-secondary:disabled,.btn.btn-secondary:disabled{border-color:#e5e7eb!important;color:#9ca3af!important;cursor:not-allowed!important;opacity:.6!important;pointer-events:none}.btn-secondary:disabled,.btn-secondary:disabled:hover,.btn.btn-secondary:disabled,.btn.btn-secondary:disabled:hover{background:#f5f7fa!important;box-shadow:none!important;transform:none!important}.btn-secondary:disabled:before,.btn.btn-secondary:disabled:before{display:none!important}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 12px #e74c3c4d}.btn-danger:hover{background:linear-gradient(135deg,#c0392b,#a93226);box-shadow:0 6px 16px #e74c3c66}.btn-danger:active{box-shadow:0 2px 8px #e74c3c4d;transform:translateY(0)}.btn-danger:disabled,.btn.btn-danger:disabled{color:#fff!important;cursor:not-allowed!important;opacity:.6!important;pointer-events:none}.btn-danger:disabled,.btn-danger:disabled:hover,.btn.btn-danger:disabled,.btn.btn-danger:disabled:hover{background:linear-gradient(135deg,#9ca3af,#6b7280)!important;box-shadow:none!important;transform:none!important}.btn-danger:disabled:before,.btn.btn-danger:disabled:before{display:none!important}.logout-icon{display:inline-block;font-size:1.1em;line-height:1;margin-right:4px;vertical-align:middle}.btn-warning{background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 4px 12px #f39c124d}.btn-warning:hover{background:linear-gradient(135deg,#e67e22,#d35400);box-shadow:0 6px 16px #f39c1266}.btn-warning:active{box-shadow:0 2px 8px #f39c124d;transform:translateY(0)}.btn-warning:disabled,.btn.btn-warning:disabled{color:#fff!important;cursor:not-allowed!important;opacity:.6!important;pointer-events:none}.btn-warning:disabled,.btn-warning:disabled:hover,.btn.btn-warning:disabled,.btn.btn-warning:disabled:hover{background:linear-gradient(135deg,#9ca3af,#6b7280)!important;box-shadow:none!important;transform:none!important}.btn-warning:disabled:before,.btn.btn-warning:disabled:before{display:none!important}.container{margin:0 auto;max-width:1200px;padding:20px}.header{align-items:center;background:#667eea;color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.header-title{font-size:20px;font-weight:600}.header-subtitle{color:#fffc;display:block;font-size:12px;font-weight:400;margin-top:4px}.user-info{align-items:center;display:flex;gap:12px}.user-avatar{background:#fff3;height:32px;width:32px}.breadcrumb{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;color:#667eea;display:flex;font-size:13px;gap:8px;padding:12px 20px}.breadcrumb a,.breadcrumb button{background:none;border:none;color:#667eea;cursor:pointer;font-family:inherit;font-size:inherit;padding:0;text-decoration:none}.breadcrumb a:hover,.breadcrumb button:hover{text-decoration:underline}.breadcrumb-separator{color:#7f8c8d}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-footer{background:#f8f9fa;border-top:1px solid #e0e0e0;color:#7f8c8d;font-size:12px;margin-top:auto;padding:10px 20px;text-align:center}.tool-form-card{margin:0 auto 16px;max-width:900px}.tool-selection-card{margin:0 auto;max-width:1000px}.tool-selection-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.tool-selection-card-item{position:relative;text-align:center}.tool-selection-card-item.recommended{border-color:#667eea;box-shadow:0 4px 16px #667eea33}.tool-selection-card-item.disabled{cursor:not-allowed;opacity:.6}.tool-badge{border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px;padding:6px 12px;position:absolute;right:16px;text-transform:uppercase;top:16px;z-index:2}.recommended-badge{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea4d;color:#fff}.warning-badge{background:#ffc107;box-shadow:0 2px 8px #ffc1074d;color:#856404}.tool-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:56px;margin-bottom:16px;transition:transform .3s ease}.tool-selection-card-item:hover .tool-icon{transform:scale(1.1) rotate(5deg)}.tool-card-title{color:#667eea;font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:12px}.tool-card-description{color:#666;font-size:14px;line-height:1.6;margin-bottom:20px}.tool-select-btn{margin-top:8px;width:100%}.tool-card-hint{font-size:13px;font-weight:500;margin-top:12px;text-align:center}.success-hint{color:#28a745}.error-hint{color:#e74c3c}.performance-container{padding:24px 20px}.performance-form-card{background:linear-gradient(180deg,#fff 0,#fafafa);border:1px solid #e8e8e8;border-radius:12px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;overflow:hidden;padding:40px;position:relative}.performance-form-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0}.form-section-title{align-items:center;color:#667eea;display:flex;font-size:24px;font-weight:700;gap:12px;margin:0 0 12px}.form-section-title:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;content:"";height:24px;width:4px}.form-section-description{color:#666;font-size:15px;line-height:1.6;margin:0 0 32px;padding-left:16px}.form-group{margin-bottom:24px}.form-group label{font-size:15px;letter-spacing:.2px;margin-bottom:10px}.form-field-help{color:#999;font-size:12px;font-style:italic;margin:-4px 0 8px}.form-group input,.form-group textarea{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:14px 16px;transition:all .2s ease;width:100%}.form-group input:hover,.form-group textarea:hover{border-color:silver}.form-input,.form-textarea{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:14px 16px;transition:all .2s ease;width:100%}.form-input:hover,.form-textarea:hover{border-color:silver}.form-group input:focus,.form-group textarea:focus,.form-input:focus,.form-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a,0 2px 8px #667eea26;outline:none;transform:translateY(-1px);transition:all .2s ease}.form-group textarea,.form-textarea{line-height:1.6;min-height:140px;resize:vertical}.form-actions{background:linear-gradient(90deg,#0000,#fafafa 50%,#0000);border-top:2px solid #f0f0f0;display:flex;flex-wrap:wrap;gap:12px;margin-left:-40px;margin-right:-40px;margin-top:40px;padding-left:40px;padding-right:40px;padding-top:28px}.card{background:linear-gradient(180deg,#fff 0,#fafafa);border:2px solid #e8e8e8;border-radius:12px;box-shadow:0 4px 12px #00000014;margin-bottom:20px;overflow:hidden;padding:28px;position:relative;transition:all .3s ease}.card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.card:hover:before{transform:scaleX(1)}.card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea26;transform:translateY(-2px)}.table-container{background:#fff;border:1px solid #e0e0e0;border-radius:4px;overflow-x:auto}.table{border-collapse:collapse;width:100%}.table thead{background:#f8f9fa}.table th{border-bottom:1px solid #e0e0e0;color:#667eea;font-size:12px;font-weight:600;padding:10px 12px;text-align:left;text-transform:uppercase}.table td{border-bottom:1px solid #f0f0f0;color:#555;font-size:13px;padding:10px 12px}.table tbody tr:hover{background:#f8f9fa}.status-badge{font-size:11px;padding:4px 10px;text-transform:uppercase}.status-completed{background:#d4edda;color:#155724}.status-failed{background:#f8d7da;color:#721c24}.status-cancelled{background:#fff3cd;color:#856404}.status-pause,.status-paused{background:#d1ecf1;color:#0c5460}.status-running{background:#cce5ff;color:#004085}.status-clickable{cursor:pointer;position:relative;transition:all .2s ease}.status-clickable:hover{box-shadow:0 2px 4px #0003;opacity:.9;transform:scale(1.05)}.status-clickable:after{content:" 👁️";font-size:1.1em}.pagination{align-items:center;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;gap:8px;justify-content:center;padding:12px 20px}.pagination-button{background:#fff;border:1px solid #e0e0e0;border-radius:4px;color:#667eea;cursor:pointer;font-size:13px;padding:6px 12px}.pagination-button:hover:not(:disabled){background:#f8f9fa;border-color:#667eea;color:#667eea}.pagination-button:disabled{cursor:not-allowed;opacity:.5}.pagination-button.active{background:#667eea;border-color:#667eea;color:#fff}.pagination-button.active:hover:not(:disabled){background:#5568d3;border-color:#5568d3;color:#fff}.pagination-info{color:#666;font-size:13px;margin:0 12px}.controls-bar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 20px}.search-box{position:relative}.search-box input{border:1px solid #e0e0e0;border-radius:4px;font-size:13px;padding:8px 35px 8px 12px}.search-icon{color:#666;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.sort-controls{align-items:center;display:flex;gap:8px}.sort-select{background:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;font-size:13px;padding:8px 12px}.results-count{color:#666;font-size:13px}.App-header{background:#fffffff2;box-shadow:0 2px 20px #0000001a;padding:2rem}.header-content{margin:0 auto;max-width:1200px;text-align:center}.App-header h1{color:#667eea;font-size:2.5rem;font-weight:700;margin:0}.tagline{color:#7f8c8d;font-size:1.1rem;margin:.5rem 0 1rem}.feature-badges{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.badge{background:#667eea;border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;padding:.4rem 1rem}.view-selector{background:linear-gradient(180deg,#fafafa 0,#fff);border-bottom:1px solid #e8e8e8;box-shadow:0 2px 4px #00000008;display:flex;gap:12px;justify-content:center;padding:20px}.view-selector button{background:#fff;border:2px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 4px #0000000d;color:#667eea;cursor:pointer;font-size:15px;font-weight:600;overflow:hidden;padding:12px 24px;position:relative;transition:all .3s ease}.view-selector button:before{background:linear-gradient(90deg,#0000,#ffffff4d,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.view-selector button:hover:before{left:100%}.view-selector button:hover:not(:disabled){background:#f8f9fa;border-color:#667eea;box-shadow:0 4px 12px #667eea33;color:#5568d3;transform:translateY(-2px)}.view-selector button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff}.view-selector button.active:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 6px 16px #667eea66;color:#fff}.view-selector button:disabled{background:#f5f5f5;border-color:#e0e0e0;color:#999;cursor:not-allowed;opacity:.4}.App-main{flex:1 1;margin:0 auto;max-width:1400px;padding:2rem;width:100%}.view-container{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.scores-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.score-box{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:15px;text-align:center}.score-label{color:#666;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.score-value{font-size:36px;font-weight:700;margin:5px 0}.score-green{color:#0cce6b}.score-yellow{color:#ffa400}.score-red{color:#ff4e42}.tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:20px}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:-2px;padding:12px 24px;transition:all .3s}.tab-button:hover{color:#667eea}.tab-button.active{border-bottom-color:#667eea;color:#667eea}.tab-content{display:none}.tab-content.active{display:block}.links-section{background:#f8f9fa;border-radius:8px;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px;padding:15px}.link-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;display:inline-block;font-size:14px;font-weight:600;padding:10px 20px;text-decoration:none;transition:all .3s}.link-button:hover{background:#34495e;box-shadow:0 4px 8px #2c3e504d;transform:translateY(-2px)}.lighthouse-viewer-link{background:#4caf50}.lighthouse-viewer-link:hover{background:#45a049}.preview-button{background:#ff9800}.preview-button:hover{background:#f57c00}.device-section{border-top:none;margin-top:0;padding-top:0}.device-section h4{display:none}.cwv-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(6,1fr);margin-top:15px}@media (max-width:1400px){.cwv-grid{grid-template-columns:repeat(5,1fr)}}@media (max-width:1200px){.cwv-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.cwv-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.cwv-grid{grid-template-columns:1fr}}.cwv-box{align-items:flex-start;background:#fff;border:2px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;padding:18px}.cwv-box h5{color:#666;font-size:14px;font-weight:500;margin-bottom:10px}.cwv-value{color:#333;font-size:24px;font-weight:700;margin-bottom:8px}.cwv-status{border:1px solid #0000;border-radius:6px;display:inline-block;font-size:13px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:6px 12px}.status-good{background:#d9ead3;border-color:#137333;color:#137333}.status-needs-improvement{background:#fff2cc;border-color:#b45309;color:#b45309}.status-poor{background:#f4cccc;border-color:#c5221f;color:#c5221f}.status-na{background:#e0e0e0;border-color:#999;color:#666}.cwv-assessment-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 4px 12px #00000026;margin-top:20px;padding:30px}.cwv-assessment-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}.cwv-assessment-title{align-items:center;color:#333;display:flex;font-size:20px;font-weight:600;gap:12px}.cwv-icon{font-size:28px}.cwv-status-badge{align-items:center;border-radius:12px;box-shadow:0 4px 8px #0003;display:flex;font-size:20px;font-weight:700;gap:10px;letter-spacing:1px;padding:16px 32px;text-transform:uppercase;transition:transform .2s,box-shadow .2s}.cwv-status-badge:hover{box-shadow:0 6px 12px #00000040;transform:translateY(-2px)}.cwv-status-badge.status-good{background:#34a853;border:2px solid #2d8f47;color:#fff}.cwv-status-badge.status-poor{background:#ea4335;border:2px solid #d32f2f;color:#fff}.cwv-status-badge.status-needs-improvement{background:#fbbc04;border:2px solid #f9ab00;color:#fff}.cwv-status-badge.status-na{background:#9aa0a6;border:2px solid #80868b;color:#fff}.cwv-status-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;font-size:24px;font-weight:900;height:32px;justify-content:center;width:32px}.cwv-status-text{font-size:22px;font-weight:800}.result-card{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;margin-bottom:15px;overflow:hidden}.result-card-header{align-items:center;background:#fff;border-bottom:2px solid #e0e0e0;cursor:pointer;display:flex;gap:15px;justify-content:space-between;padding:15px 20px}.result-card-header:hover{background:#f0f0f0}.result-card-header h3{color:#333;flex:1 1;font-size:18px;margin:0;min-width:0;overflow-wrap:break-word;word-break:break-all}.result-card-header .accordion-icon{align-items:center;color:#667eea;display:flex;flex-shrink:0;font-size:20px;justify-content:center;min-width:24px;text-align:center;transition:transform .3s}.result-card-header.active .accordion-icon{transform:rotate(180deg)}.result-card-content{max-height:0;overflow:hidden;padding:0;transition:max-height .3s ease-out}.result-card-content.active{max-height:5000px;padding:20px}.result-card.error{background:#fff5f5;border-color:#ff4d4d}.result-card.error .result-card-header{background:#fff5f5}@media (max-width:768px){.App-header h1{font-size:1.8rem}.header-content>div:first-child{align-items:flex-start!important;flex-direction:column;gap:1rem}.feature-badges{font-size:.75rem}.view-selector{flex-direction:column}.view-selector button{width:100%}.App-main{padding:1rem}}.not-found-container{align-items:center;background:#f8f9fa;display:flex;justify-content:center;min-height:100vh;padding:20px}.not-found-content{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;max-width:600px;padding:40px;text-align:center}.not-found-icon{color:#667eea;font-size:120px;font-weight:700;line-height:1;margin-bottom:20px;opacity:.8}.not-found-title{color:#667eea;font-size:32px;font-weight:600;margin-bottom:16px}.not-found-message{color:#666;font-size:16px;line-height:1.6;margin-bottom:30px}.not-found-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center}@media (max-width:768px){.header{align-items:flex-start;flex-direction:column;gap:12px;padding:12px 16px}.header-title{font-size:18px}.header-subtitle{font-size:11px}.user-info{flex-wrap:wrap;gap:8px;justify-content:space-between;width:100%}.user-info>div:first-child{display:none}.user-info .btn{flex:1 1;font-size:12px;min-width:0;padding:6px 10px}.container{padding:12px!important}.card{margin-bottom:12px;padding:16px}.breadcrumb{flex-wrap:wrap;font-size:12px;gap:4px;padding:10px 12px}.breadcrumb-separator{margin:0 4px}.form-group input,.form-group textarea{font-size:16px;padding:12px}.tool-form-card{margin:0 0 12px}.performance-container{padding:16px 12px}.performance-form-card{padding:20px 16px}.form-section-title{font-size:18px}.form-section-description{font-size:13px;margin-bottom:20px}.form-actions{margin-top:24px;padding-top:20px}.btn{font-size:14px;min-height:44px;padding:12px 16px}.container>div[style*=grid]{gap:12px!important;grid-template-columns:1fr!important}.card[style*="cursor: pointer"]{margin-bottom:16px}.view-selector{flex-direction:column;gap:8px}.view-selector button{font-size:14px;padding:12px;width:100%}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{font-size:12px;min-width:600px}.table td,.table th{padding:8px 10px;white-space:nowrap}.cwv-grid{gap:12px;grid-template-columns:1fr!important}.cwv-assessment-header{align-items:flex-start;flex-direction:column}.cwv-status-badge{font-size:16px;justify-content:center;padding:12px 20px;width:100%}.result-card-header{flex-wrap:wrap;padding:12px 16px}.result-card-header h3{font-size:14px;word-break:break-word}.scores-grid{gap:12px;grid-template-columns:repeat(2,1fr)!important}.tabs{flex-wrap:wrap}.tabs .tab-button{flex:1 1;font-size:13px;min-width:0;padding:10px 8px}.not-found-content{padding:30px 20px}.not-found-icon{font-size:80px}.not-found-title{font-size:24px}.not-found-message{font-size:14px}.not-found-actions{flex-direction:column;width:100%}.not-found-actions .btn{margin-left:0!important;margin-top:10px;width:100%}.app-footer{font-size:11px;padding:12px}}@media (max-width:480px){.header{padding:10px 12px}.header-title{font-size:16px}.user-info{align-items:stretch;flex-direction:column;width:100%}.user-info .btn{margin:4px 0;width:100%}.container{padding:8px!important}.card{padding:12px}.btn{font-size:14px;padding:14px 16px}.form-group label{font-size:13px}.breadcrumb{padding:8px 10px}.breadcrumb,.breadcrumb button{font-size:11px}.tool-form-card>div[style*=grid]{grid-template-columns:1fr!important}.controls-bar{flex-direction:column;gap:10px}.results-count,.search-box,.sort-controls{width:100%}.pagination{flex-wrap:wrap;gap:4px;justify-content:center;padding:12px 8px}.pagination-button{flex:0 1 auto;font-size:11px;min-width:36px;padding:6px 10px}.pagination-info{font-size:12px;margin:8px 0 4px;order:-1;text-align:center;width:100%}.cwv-box{padding:12px}.cwv-value{font-size:20px}.score-box{padding:12px}.score-value{font-size:28px}.links-section{flex-direction:column}.link-button{margin:4px 0;text-align:center;width:100%}}@media (hover:none) and (pointer:coarse){.breadcrumb a,.breadcrumb button,.btn,.table tbody tr{min-height:44px;min-width:44px}.btn:active{transform:scale(.98);transition:transform .1s}.breadcrumb button,.btn{-webkit-tap-highlight-color:rgba(0,0,0,.1);-webkit-user-select:none;user-select:none}}@media (max-width:768px) and (orientation:landscape){.header{padding:8px 16px}.container{padding:10px!important}}@media (min-width:1400px){.container{max-width:1400px}}.responsive-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.responsive-grid-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}@media (max-width:768px){.responsive-grid,.responsive-grid-2{gap:12px;grid-template-columns:1fr}}.dashboard-container{background:linear-gradient(180deg,#fafafa 0,#fff);margin:0 auto;max-width:1400px;min-height:calc(100vh - 80px);padding:32px 24px}.dashboard-header-section{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 20px #667eea33;display:flex;gap:24px;justify-content:space-between;margin-bottom:32px;overflow:hidden;padding:28px;position:relative}.dashboard-header-section:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='a' width='40' height='40' patternUnits='userSpaceOnUse'%3E%3Cpath d='M40 0H0v40' fill='none' stroke='rgba(255,255,255,0.05)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.dashboard-header-content{flex:1 1;position:relative;z-index:1}.dashboard-header-section .page-title{color:#fff;font-size:32px;font-weight:700;margin-bottom:8px;text-shadow:0 2px 4px #0000001a}.dashboard-header-section .page-subtitle{color:#fffffff2;font-size:15px;margin-bottom:0}.dashboard-header-actions{align-items:flex-start;display:flex;padding-top:4px;position:relative;z-index:1}.btn-add-new-run{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #0000;border-radius:8px;box-shadow:0 4px 12px #667eea4d;color:#fff!important;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.btn-add-new-run:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 6px 16px #667eea66;color:#fff!important;transform:translateY(-2px)}.btn-add-new-run,.btn-add-new-run *,.btn-add-new-run:after,.btn-add-new-run:before{color:#fff!important}.btn-add-new-run{-webkit-text-fill-color:#fff}@media (max-width:768px){.dashboard-header-section{align-items:stretch;flex-direction:column;gap:16px;padding-bottom:16px}.dashboard-header-actions{padding-top:0;width:100%}.dashboard-header-actions .btn{width:100%}}.activity-page-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:12px 40px}.activity-page-header,.activity-page-title{cursor:default;pointer-events:auto;-webkit-user-select:text;user-select:text}.activity-page-title{color:#667eea;font-size:18px;margin:0;position:relative;z-index:1}.activity-page-title .activity-domain-title{pointer-events:auto;-webkit-user-select:text;user-select:text}.activity-domain-title{color:#667eea;font-size:16px;font-weight:400}.project-domain-title{color:#666;font-style:italic;font-weight:400}.activity-page-actions{align-items:center;display:flex;gap:10px}.btn-back-dashboard{font-size:14px;padding:8px 16px;white-space:nowrap}.tool-page-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea33;color:#fff;display:flex;justify-content:center;overflow:hidden;padding:32px 20px;position:relative}.tool-page-header:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='100' height='100' xmlns='http://www.w3.org/2000/svg'%3E%3Cdefs%3E%3Cpattern id='a' width='40' height='40' patternUnits='userSpaceOnUse'%3E%3Cpath d='M40 0H0v40' fill='none' stroke='rgba(255,255,255,0.05)'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.3;position:absolute;right:0;top:0}.tool-page-header .tool-page-title{max-width:900px;position:relative;text-align:center;width:100%;z-index:1}.tool-page-header-actions{align-items:center;display:flex;gap:10px}.tool-page-title{font-size:28px;font-weight:700;letter-spacing:-.5px;text-shadow:0 2px 4px #0000001a}.tool-page-subtitle{color:#fffffff2;display:block;font-size:14px;font-weight:400;line-height:1.5;margin-top:8px;text-align:center}.page-title{color:#667eea;font-size:32px;font-weight:700;letter-spacing:-.5px;margin-bottom:12px}.page-subtitle{color:#666;font-size:16px;line-height:1.6;margin-bottom:32px}.search-container{margin-bottom:24px}.search-input{background:#fff;border:2px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 4px #0000000d;font-family:inherit;font-size:15px;max-width:600px;padding:14px 20px;transition:all .2s ease;width:100%}.search-input:hover{border-color:silver}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a,0 4px 12px #667eea26;outline:none;transform:translateY(-1px)}.loading-center{background:linear-gradient(180deg,#fafafa 0,#fff);border-radius:12px;margin:32px 0;padding:60px 40px;text-align:center}.loading-text{color:#667eea;font-size:16px;font-weight:500;margin-top:16px}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto;width:50px}.tiles-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:32px}.activity-tile{background:linear-gradient(180deg,#fff 0,#fafafa);border:2px solid #e8e8e8;border-radius:12px;box-shadow:0 2px 8px #0000000f;cursor:pointer;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.activity-tile:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.activity-tile:hover:before{transform:scaleX(1)}.activity-tile:hover{background:linear-gradient(180deg,#fff 0,#f8f9fa);border-color:#667eea;box-shadow:0 8px 24px #667eea33;transform:translateY(-4px)}.tile-header{margin-bottom:12px}.tile-title{color:#667eea;font-size:16px;font-weight:600;margin-bottom:4px;word-break:break-word}.tile-url{color:#667eea;font-size:13px;text-decoration:none;word-break:break-all}.tile-url:hover{text-decoration:underline}.tile-badges-container{display:flex;flex-wrap:wrap;gap:6px}.tile-meta{border-top:1px solid #f0f0f0;color:#666;font-size:12px;justify-content:space-between;margin-top:12px;padding-top:12px}.tile-meta,.tile-meta-left{align-items:center;display:flex}.tile-meta-left{flex:1 1;gap:12px}.tile-meta-right{align-items:center;display:flex;gap:12px}.tile-badge{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;padding:4px 8px;text-transform:uppercase}.badge-scanner{background-color:#e3f2fd;color:#1976d2}.badge-performance{background-color:#f3e5f5;color:#7b1fa2}.badge-both{background-color:#fff3e0;color:#e65100}.badge-completed{background-color:#e8f5e9;color:#2e7d32}.badge-running{background-color:#fff3e0;color:#e65100}.badge-failed{background-color:#ffebee;color:#c62828}.tile-date{color:#999;font-size:12px}.empty-state{background:linear-gradient(180deg,#fafafa 0,#fff);border:2px dashed #e0e0e0;border-radius:12px;margin:32px 0;padding:80px 20px;text-align:center}.empty-state-icon{filter:grayscale(.3);font-size:72px;margin-bottom:20px;opacity:.6}.empty-state-text{color:#667eea;font-size:18px;font-weight:500}.activity-table-wrapper{margin-bottom:24px}.activity-table-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px 10px 0 0;box-shadow:0 2px 8px #667eea33;color:#fff;display:flex;gap:12px;padding:16px 24px}.activity-table-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1));font-size:22px}.activity-table-title{font-size:18px;font-weight:700;letter-spacing:.3px}.activity-tabs-container{border-bottom:2px solid #e0e0e0;display:flex;gap:12px;margin-bottom:24px;padding-bottom:0}.activity-tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:-2px;padding:14px 28px;position:relative;transition:all .3s ease}.activity-tab-button:hover{background:#667eea0d;color:#667eea}.activity-tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-color:#667eea;box-shadow:0 2px 8px #667eea33;color:#fff}.activity-container-wrapper{padding:24px}.activity-loading-center{background:linear-gradient(180deg,#fafafa 0,#fff);border-radius:12px;margin:32px 0;padding:60px 40px;text-align:center}.activity-loading-text{margin-top:16px}.activity-empty-cell,.activity-loading-text{color:#667eea;font-size:16px;font-weight:500}.activity-empty-cell{padding:50px 40px;text-align:center}.activity-url-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-empty-dash{color:#bdc3c7}.activity-rerun-btn-small{font-size:12px;padding:6px 12px}.login-title{color:#667eea;font-size:28px;font-weight:700;letter-spacing:-.5px;margin-bottom:8px}.report-links-title{color:#667eea;font-size:18px;font-weight:600;margin-bottom:10px}.back-button{align-items:center;background:none;border:none;border-radius:6px;color:#667eea;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;margin-bottom:20px;padding:8px 12px;text-align:left;text-decoration:none;transition:all .2s ease}.back-button:hover{background-color:#f0f0f0;color:#5568d3}.tool-tiles{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-top:32px}.tool-tile{background:linear-gradient(180deg,#fff 0,#fafafa);border:2px solid #e8e8e8;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;overflow:hidden;padding:32px;position:relative;text-align:center;transition:all .3s ease}.tool-tile:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:5px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.tool-tile:hover:before{transform:scaleX(1)}.tool-tile:hover{background:linear-gradient(180deg,#fff 0,#f8f9fa);border-color:#667eea;box-shadow:0 12px 32px #667eea40;transform:translateY(-6px)}.tool-tile-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:56px;margin-bottom:20px;transition:transform .3s ease}.tool-tile:hover .tool-tile-icon{transform:scale(1.1) rotate(5deg)}.tool-tile-title{color:#667eea;font-size:22px;font-weight:700;letter-spacing:-.3px;margin-bottom:12px}.tool-tile-description{color:#666;font-size:15px;line-height:1.6}@media (max-width:768px){.tiles-grid{grid-template-columns:1fr}.nav-links{display:none}.dashboard-container{padding:20px 16px}.tool-tiles{grid-template-columns:1fr}.controls-bar{align-items:stretch;flex-direction:column;gap:12px;padding:12px}.search-box{width:100%}.search-box input{font-size:16px;width:100%}.sort-controls{width:100%}.sort-select{font-size:14px;padding:10px;width:100%}.results-count{font-size:12px;text-align:center;width:100%}.pagination{flex-wrap:wrap;gap:4px;justify-content:center;padding:12px 8px}.pagination-button{flex:0 1 auto;font-size:11px;min-width:36px;padding:6px 10px}.pagination-info{font-size:12px;margin:8px 0 4px;order:-1;text-align:center;width:100%}}@media (max-width:450px){.pagination{gap:3px;padding:10px 6px}.pagination-button{flex:0 1 auto;font-size:10px;min-width:30px;padding:5px 6px}.pagination-info{font-size:11px;line-height:1.4;margin:6px 0 3px}}@media (max-width:768px){.progress-tracker{padding:16px}.progress-actions{flex-direction:column;gap:10px}.progress-actions .btn{margin-left:0!important;width:100%}.job-metadata{font-size:12px}.cancel-message,.completion-message,.error-message,.pause-message{font-size:14px;padding:16px}.device-section{padding:12px}.scores-grid{gap:10px;grid-template-columns:repeat(2,1fr)!important}.score-box{padding:10px}.score-label{font-size:11px}.score-value{font-size:24px}.cwv-grid{grid-template-columns:1fr!important}.cwv-box{padding:12px}.links-section{flex-direction:column;gap:8px}.link-button{font-size:13px;padding:12px;width:100%}.login-container{margin:20px;padding:20px}.login-card{padding:24px 20px}.login-card h1{font-size:24px}.login-card input{font-size:16px;padding:14px}}.basecamp-header{background-color:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 1px 3px #0000000d;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.basecamp-header,.header-left{align-items:center;display:flex}.header-left{gap:24px}.logo{align-items:center;color:#667eea;display:flex;font-size:20px;font-weight:600;height:50px;transition:opacity .2s ease}.logo:hover{opacity:.8}.logo-image{display:block;height:75px;max-width:250px;object-fit:cover;width:250px}.logo-text{color:#667eea;display:block;font-size:20px;font-weight:600}.nav-links{display:flex;gap:20px}.nav-link{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-family:inherit;font-size:14px;padding:6px 12px;text-decoration:none;transition:background-color .2s}.nav-link:hover{background-color:#f0f0f0}.header-right{align-items:center;display:flex;gap:12px}.header-right,.user-dropdown-container{position:relative}.user-avatar-button{align-items:center;background:none;border:none;cursor:pointer;display:flex;justify-content:center;padding:0;transition:transform .2s}.user-avatar-button:hover{transform:scale(1.05)}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.user-dropdown{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:400px;min-width:130px;padding:16px 0;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.dropdown-section{padding:0 20px}.dropdown-section-header{display:flex;gap:12px;margin-bottom:12px}.dropdown-icon{flex-shrink:0;font-size:20px}.dropdown-section-title{color:#333;font-size:14px;font-weight:600;margin-bottom:4px}.dropdown-section-title-bold{color:#333;font-size:14px;font-weight:600;margin-bottom:12px}.dropdown-section-text{color:#666;font-size:13px;line-height:1.4}.dropdown-button{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;margin-bottom:12px;padding:8px 12px;transition:background .2s;width:100%}.dropdown-button:hover{background:#34495e}.dropdown-links{display:flex;flex-direction:column}.dropdown-link{color:#667eea;display:block;font-size:13px;font-weight:600;padding:8px 0;text-decoration:none;transition:color .2s}.dropdown-link:hover{color:#764ba2;text-decoration:underline}.dropdown-link-button{background:none;border:none;cursor:pointer;font-family:inherit;padding:8px 0;text-align:left}.dropdown-divider{background:#e0e0e0;height:1px;margin:16px 0}@media (max-width:768px){.nav-links{display:none}.basecamp-header{padding:12px 16px}}.crawler-form-container{background:#fff;border:1px solid #e0e0e0;border-radius:4px;box-shadow:none;margin:0 auto 16px;max-width:900px;padding:20px}.form-header{margin-bottom:2rem;text-align:center}.form-header h2{color:#667eea;margin:0 0 .5rem}.form-header p{color:#7f8c8d;margin:0}.crawler-form{margin:0 auto;max-width:800px}.form-section{border-bottom:2px solid #ecf0f1;margin-bottom:2rem;padding-bottom:2rem}.form-section:last-child{border-bottom:none}.form-section h3{color:#667eea;font-size:1.2rem;margin:0 0 1.5rem}.form-group{margin-bottom:16px}.form-group label{color:#667eea;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:1px solid #e0e0e0;border-radius:4px;font-family:inherit;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-group textarea{min-height:120px;resize:vertical}.help-text{color:#95a5a6;display:block;font-size:.85rem;margin-top:.5rem}.or-separator{color:#95a5a6;font-size:.9rem;font-weight:600;letter-spacing:.1em;margin:1.5rem 0;position:relative;text-align:center}.or-separator:after,.or-separator:before{background:linear-gradient(90deg,#0000,#e0e0e0,#0000);content:"";height:1px;position:absolute;top:50%;width:45%}.or-separator:before{left:0}.or-separator:after{right:0}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.btn-advanced{background:none;border:none;color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;padding:.5rem 0;text-align:left;transition:color .3s ease;width:100%}.btn-advanced:hover{color:#667eea}.advanced-options,.feature-options{animation:slideDown .3s ease;background:#f8f9fa;border-radius:8px;margin-top:1rem;padding:1.5rem}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:2000px;opacity:1}}.feature-option{background:#fff;border:2px solid #ecf0f1;border-radius:8px;margin-bottom:1.5rem;padding:1.5rem;transition:border-color .3s ease}.feature-option:hover{border-color:#667eea}.feature-option.highlight{background:#2c3e500d;border-color:#667eea}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:1rem;gap:.75rem}.checkbox-label input[type=checkbox]{cursor:pointer;height:20px;width:20px}.feature-title{color:#667eea;font-size:1.05rem;font-weight:600}.feature-desc{color:#7f8c8d;font-size:.95rem;line-height:1.6;margin:.75rem 0}.sub-option{background:#f8f9fa;border-radius:6px;margin-top:1rem;padding:1rem}.sub-option label{color:#667eea;display:inline-block;font-weight:600;margin-right:.75rem}.sub-option input{border:2px solid #ecf0f1;border-radius:6px;padding:.5rem;width:100px}.feature-content{flex:1 1}.feature-icon{font-size:2rem;margin-bottom:.5rem}.info-box{background:#e8f4f8;border-left:4px solid #3498db;border-radius:6px;margin-top:1rem;padding:1rem 1.5rem}.info-box strong{color:#667eea}.info-box ul{margin:.5rem 0 0;padding-left:1.5rem}.info-box li{color:#34495e;line-height:1.5;margin-bottom:.5rem}.error-message{border-radius:8px;color:#c0392b;margin:1rem 0;padding:1rem}.form-actions{margin-top:2rem;text-align:center}.btn-submit{align-items:center;background:#667eea;border:none;border-radius:8px;box-shadow:0 4px 12px #2c3e5066;color:#fff;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:600;gap:.5rem;padding:1rem 3rem;transition:all .3s ease}.btn-submit:hover:not(:disabled){box-shadow:0 6px 20px #2c3e5080;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.6;transform:none}.crawler-form .btn .spinner,.crawler-form .btn-primary .spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;flex-shrink:0;height:16px;margin-right:.5rem;vertical-align:middle;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.crawler-form .btn,.crawler-form .btn-primary{align-items:center;display:inline-flex;gap:.5rem;justify-content:center}.features-summary{border-top:2px solid #ecf0f1;margin-top:3rem;padding-top:2rem}.features-summary h4{color:#667eea;font-size:1.3rem;margin-bottom:1.5rem;text-align:center}.feature-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.feature-card{background:#fff;border:2px solid #ecf0f1;border-radius:8px;padding:1.5rem;text-align:center;transition:all .3s ease}.feature-card:hover{border-color:#667eea;box-shadow:0 6px 20px #0000001a;transform:translateY(-4px)}.feature-card .feature-icon{font-size:2.5rem;margin-bottom:.5rem}.feature-card h5{color:#667eea;font-size:1rem;margin:0 0 .5rem}.feature-card p{color:#7f8c8d;font-size:.9rem;margin:0}@media (max-width:768px){.crawler-form-container{padding:1rem}.form-row{grid-template-columns:1fr}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.btn-submit{padding:1rem;width:100%}}.progress-tracker{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto;max-width:900px;padding:2rem}.progress-tracker.error,.progress-tracker.loading{padding:3rem;text-align:center}.progress-header{margin-bottom:2rem;text-align:center}.progress-header h2{color:#667eea;font-size:2rem;margin:0 0 .5rem}.job-url{color:#667eea;font-size:1.1rem;font-weight:600;margin:.5rem 0}.job-id{color:#95a5a6;font-size:.9rem;margin:0}.running-info{margin:1.5rem 0 1rem;text-align:center}.running-count{color:#667eea;font-size:1.3rem;font-weight:700;margin-bottom:.5rem}.current-url{background:#f8f9fa;border-radius:6px;color:#667eea;display:inline-block;font-size:.95rem;margin-top:.5rem;max-width:100%;overflow:hidden;padding:.5rem 1rem;text-overflow:ellipsis;white-space:nowrap}.url-label{color:#7f8c8d;font-weight:600;margin-right:.5rem}.url-value{color:#667eea;font-weight:500}.progress-bar-container{background:#ecf0f1;border-radius:30px;box-shadow:inset 0 2px 4px #0000001a;height:60px;margin:2rem 0;overflow:hidden;position:relative;width:100%}.progress-bar-fill{align-items:center;background:#667eea;display:flex;height:100%;justify-content:flex-end;min-width:60px;padding-right:1rem;transition:width .5s ease}.progress-text{color:#fff;font-size:1.2rem;font-weight:700;text-shadow:0 2px 4px #0003}.status-message{margin:2rem 0;text-align:center}.status-message p{color:#7f8c8d;font-size:1.1rem;margin:0}.progress-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:2rem 0}.stat-card{background:#f8f9fa;border:2px solid #ecf0f1;border-radius:8px;padding:1.5rem;text-align:center}.stat-card.success{background:#e8f8f5;border-color:#27ae60}.stat-card.failed{background:#fee;border-color:#e74c3c}.stat-card.resumed{background:#e8f4f8;border-color:#3498db}.stat-value{color:#667eea;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#7f8c8d;font-size:.9rem;letter-spacing:.5px;text-transform:uppercase}.completion-message{animation:slideIn .4s ease-out;border:2px solid #27ae60;border-radius:12px;box-shadow:0 4px 12px #27ae6026;margin:2.5rem 0;padding:2.5rem 2rem;text-align:center}.success-icon{animation:bounce .6s ease-out;display:block;font-size:4rem;margin-bottom:1.25rem}@keyframes bounce{0%{opacity:0;transform:scale(.8) translateY(-10px)}60%{transform:scale(1.05)}to{opacity:1;transform:scale(1) translateY(0)}}.completion-message h3{font-size:1.4rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.completion-message p{font-size:1rem;line-height:1.6;margin:.5rem 0}.error-message{animation:slideIn .4s ease-out;border:2px solid #e74c3c;border-left-width:5px;border-radius:12px;box-shadow:0 4px 12px #e74c3c26;margin:2.5rem 0;padding:2.5rem 2rem}.error-message h4{font-size:1.3rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.error-message p{font-size:1rem;line-height:1.6;margin:.5rem 0}.pause-message{animation:slideIn .4s ease-out;border:2px solid #95a5a6;border-left:5px solid #3498db;border-radius:12px;box-shadow:0 4px 12px #3498db1a;margin:2.5rem 0;padding:2.5rem 2rem;text-align:center}.pause-message h4{font-size:1.3rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.pause-message p{font-size:1rem;line-height:1.6;margin:.75rem 0}.pause-message button{margin-top:1.5rem}.resume-banner{background:#2c3e501a;border-left:4px solid #667eea;border-radius:6px;margin:1rem 0;padding:1rem}.resume-banner p{color:#667eea;font-weight:600;margin:0}.progress-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin:2rem 0;text-align:center}.btn-primary{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-primary:hover{box-shadow:0 6px 20px #2c3e5066;transform:translateY(-2px)}.btn-secondary{background:#ecf0f1;border:none;border-radius:8px;color:#667eea;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 2rem;transition:all .3s ease}.btn-secondary:hover{background:#bdc3c7}.btn-danger{background:#e74c3c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .25s ease}.btn-danger:hover{box-shadow:0 6px 20px #e74c3c59;transform:translateY(-2px)}.btn-danger:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-warning{background:#f39c12;border:none;border-radius:8px;box-shadow:0 4px 15px #f39c124d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-warning:hover{box-shadow:0 6px 20px #f39c1266;transform:translateY(-2px)}.btn-warning:disabled{cursor:not-allowed;opacity:.6;transform:none}.cancel-message,.completion-message,.error-message,.pause-message{background:#f8f9fa;border:2px solid #ecf0f1;border-radius:8px;margin:2rem 0;padding:1.5rem;text-align:center}.completion-message{background:#e8f8f5;border-color:#27ae60}.completion-message h3{color:#27ae60;margin:0 0 .5rem}.completion-message p{color:#7f8c8d;margin:0}.error-message{background:#fee;border-color:#e74c3c}.error-message h4{color:#c0392b;margin:0 0 .5rem}.error-message p{color:#e74c3c;margin:0}.cancel-message{animation:slideIn .4s ease-out;background:#fdeaea;border:2px solid #e74c3c;border-left-width:5px;border-radius:12px;box-shadow:0 4px 12px #e74c3c26;margin:2.5rem 0;padding:2.5rem 2rem;text-align:center}.cancel-message .cancel-icon{animation:pulse .6s ease-out}@keyframes pulse{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.cancel-message h4{color:#c0392b;font-size:1.3rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.cancel-message .cancel-icon{display:block;font-size:3rem;margin-bottom:1rem}.cancel-message p{color:#7f8c8d;font-size:1rem;line-height:1.6;margin:.5rem 0}.cancel-message p:first-of-type{margin-top:0}.cancel-message p:last-of-type{margin-bottom:0}.pause-message{background:#f8f9fa;border-color:#95a5a6}.pause-message h4{color:#667eea;margin:0 0 .5rem}.pause-message p{color:#7f8c8d;margin:.5rem 0}.pause-message button{margin-top:1rem}.job-metadata{border-top:2px solid #ecf0f1;margin-top:2rem;padding-top:2rem;text-align:center}.job-metadata p{color:#95a5a6;font-size:.9rem;margin:.25rem 0}@media (max-width:768px){.progress-tracker{padding:1rem}.progress-bar-container{height:50px}.progress-text{font-size:1rem}.stat-value{font-size:1.5rem}.running-count{font-size:1.1rem}.current-url{font-size:.85rem;max-width:90%;padding:.4rem .8rem}.progress-actions{flex-direction:column;gap:.75rem;width:100%}.progress-actions .btn{margin-left:0!important;margin-right:0!important;max-width:300px;width:100%}}@media (min-width:769px) and (max-width:1024px){.progress-actions{flex-wrap:wrap;gap:.75rem}.progress-actions .btn{flex:0 1 auto;margin-left:0!important;margin-right:0!important;min-width:120px}}.results-display{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;padding:2rem}.results-header{margin-bottom:2rem}.cancelled-message,.error-box,.loading-message{animation:slideIn .4s ease-out;border:2px solid #ecf0f1;border-radius:12px;box-shadow:0 4px 12px #00000014;margin:2.5rem 0;padding:2.5rem 2rem;text-align:center}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-box{background:#fee;border-color:#e74c3c;border-left:5px solid #e74c3c}.error-box h3{color:#c0392b;font-size:1.4rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.error-box p{color:#e74c3c;font-size:1rem;line-height:1.6;margin:.5rem 0}.loading-message{background:#ecf7ff;border-color:#3498db;border-left:5px solid #3498db}.loading-message p{color:#2980b9;font-size:1.1rem;font-weight:500;line-height:1.6;margin:0}.cancelled-message{background:#fdeaea;border-color:#e74c3c;border-left:5px solid #e74c3c}.cancelled-message h3{color:#c0392b;font-size:1.4rem;font-weight:700;letter-spacing:.5px;margin:0 0 .75rem}.cancelled-message p{color:#7f8c8d;font-size:1rem;line-height:1.6;margin:.5rem 0}.results-header h2{color:#667eea;margin:0 0 .5rem}.crawl-url{color:#667eea;font-weight:600;margin:.5rem 0 1.5rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin:1.5rem 0}.drive-link{margin:1.5rem 0;text-align:center}.btn-drive{background:#34a853;border-radius:8px;color:#fff;display:inline-block;font-weight:600;padding:.75rem 2rem;text-decoration:none;transition:all .3s ease}.btn-drive:hover{background:#2d8e48;box-shadow:0 6px 20px #34a85366;transform:translateY(-2px)}.results-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin:2rem 0}.filter-buttons{display:flex;flex:1 1;gap:.5rem}.filter-buttons button{background:#fff;border:2px solid #ecf0f1;border-radius:6px;color:#667eea;cursor:pointer;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.filter-buttons button:hover{border-color:#667eea}.filter-buttons button.active{background:#667eea;border-color:#667eea;color:#fff}.search-box{flex:1 1;min-width:250px}.search-box input{border:2px solid #ecf0f1;border-radius:6px;font-size:.95rem;padding:.5rem 1rem;width:100%}.search-box input:focus{border-color:#667eea;outline:none}.btn-export{background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.5rem 1.5rem;transition:all .3s ease}.btn-export:hover{background:#2980b9;transform:translateY(-2px)}.results-table-container{-webkit-overflow-scrolling:touch;border:2px solid #ecf0f1;border-radius:8px;margin:2rem 0;overflow-x:auto;overflow-y:visible}.results-table{border-collapse:collapse;font-size:.9rem;width:100%}.results-table thead{background:#f8f9fa;position:-webkit-sticky;position:sticky;top:0;z-index:10}.results-table th{border-bottom:2px solid #ecf0f1;color:#667eea;font-weight:700;padding:1rem;text-align:left;white-space:nowrap}.results-table td{border-bottom:1px solid #ecf0f1;color:#34495e;padding:1rem}.results-table tr:hover{background:#f8f9fa}.results-table tr.error-row{background:#fee}.results-table tr.error-row:hover{background:#fdd}.url-cell{word-wrap:break-word;max-width:400px;min-width:200px}.url-cell,.url-cell a{overflow-wrap:break-word}.url-cell a{color:#667eea;display:inline-block;line-height:1.5;max-width:100%;text-decoration:none;word-break:break-word}.url-cell a:hover{text-decoration:underline}.url-cell .error-message{color:#e74c3c;font-size:.85rem;margin-top:.25rem}.description-cell,.title-cell{max-width:300px}.status-badge{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:600;padding:.25rem .75rem}.status-badge.status-2{background:#27ae60;color:#fff}.status-badge.status-3{background:#3498db;color:#fff}.status-badge.status-4{background:#e67e22;color:#fff}.status-badge.status-5{background:#e74c3c;color:#fff}.status-badge.status-0{background:#95a5a6;color:#fff}.warning-icon{cursor:help;display:inline-block;font-size:1.1em;margin-left:.5rem;position:relative;vertical-align:middle}.warning-icon:hover{opacity:.8;transform:scale(1.1);transition:all .2s ease}.warning-icon[title]:hover:after{word-wrap:break-word;background:#667eea;border-radius:6px;box-shadow:0 4px 12px #0000004d;color:#fff;content:attr(title);font-size:.85rem;margin-bottom:.5rem;max-width:300px;padding:.5rem .75rem;text-align:left;white-space:nowrap;white-space:normal;z-index:1000}.warning-icon[title]:hover:after,.warning-icon[title]:hover:before{bottom:100%;left:50%;pointer-events:none;position:absolute;transform:translateX(-50%)}.warning-icon[title]:hover:before{border:6px solid #0000;border-top-color:#667eea;content:"";margin-bottom:-.5rem;z-index:1001}.no-results{color:#95a5a6;padding:3rem;text-align:center}.results-actions{margin:2rem 0;text-align:center}.pagination-controls{background:#f8f9fa;border-radius:8px;flex-wrap:wrap;justify-content:space-between;margin:2rem 0;padding:1rem}.pagination-controls,.pagination-info{align-items:center;display:flex;gap:1rem}.pagination-info,.pagination-select{color:#667eea;font-size:.9rem}.pagination-select{background:#fff;border:2px solid #ecf0f1;border-radius:6px;cursor:pointer;padding:.5rem 1rem;transition:all .3s ease}.pagination-select:focus{border-color:#667eea;outline:none}.pagination-buttons{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.pagination-btn{background:#fff;border:2px solid #ecf0f1;border-radius:6px;color:#667eea;cursor:pointer;font-size:.9rem;font-weight:600;padding:.5rem 1rem;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background:#667eea;border-color:#667eea;color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-page{color:#667eea;font-size:.9rem;font-weight:600;padding:.5rem 1rem}@media (max-width:768px){.results-display{padding:1rem}.results-controls{align-items:stretch}.filter-buttons,.results-controls{flex-direction:column}.filter-buttons button{width:100%}.results-table-container{border:none;margin:1rem 0;overflow-x:visible}.results-table,.results-table tbody,.results-table td,.results-table th,.results-table thead,.results-table tr{display:block;width:100%}.results-table thead{display:none}.results-table tr{background:#fff;border:2px solid #ecf0f1;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:block;margin-bottom:1.5rem;padding:1rem;transition:all .3s ease}.results-table tr:hover{box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.results-table tr.error-row{background:#fee;border-color:#e74c3c}.results-table tr.error-row:hover{background:#fdd;box-shadow:0 4px 12px #e74c3c4d}.results-table td{border:none;border-bottom:1px solid #ecf0f1;display:flex;flex-direction:column;padding:.75rem 0;text-align:left}.results-table td:last-child{border-bottom:none;padding-bottom:0}.results-table td:first-child{padding-top:0}.results-table td:before{color:#667eea;content:attr(data-label);display:block;font-size:.75rem;font-weight:700;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.url-cell{word-wrap:break-word;min-width:0;width:100%}.url-cell,.url-cell a{max-width:100%;overflow-wrap:break-word}.url-cell a{color:#667eea;display:block;font-weight:500;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;line-height:1.6;word-break:break-word}.description-cell,.title-cell{word-wrap:break-word;max-width:100%;min-width:0;overflow-wrap:break-word;width:100%}.status-badge{display:inline-block;margin-top:.25rem}.pagination-controls{gap:.75rem;padding:.75rem}.pagination-controls,.pagination-info{align-items:stretch;flex-direction:column}.pagination-info{font-size:.85rem;gap:.5rem;width:100%}.pagination-buttons{flex-wrap:wrap;gap:.5rem;justify-content:center;width:100%}.pagination-btn{flex:1 1 auto;font-size:.85rem;max-width:120px;min-width:70px;padding:.5rem .75rem}.pagination-page{font-size:.85rem;order:2;padding:.5rem 0;text-align:center;width:100%}}@media (max-width:450px){.results-display{padding:.75rem}.results-table-container{border-radius:6px;margin:1rem 0}.results-table tr{margin-bottom:1rem;padding:.75rem}.results-table td{font-size:.8rem;padding:.6rem 0}.results-table td:before{font-size:.7rem;margin-bottom:.4rem}.url-cell{word-wrap:break-word;max-width:100%;min-width:0;overflow-wrap:break-word}.url-cell a{font-size:.8rem;hyphens:auto;-webkit-hyphens:auto;-ms-hyphens:auto;line-height:1.6;overflow-wrap:break-word;word-break:break-word}.description-cell,.title-cell{word-wrap:break-word;font-size:.8rem;max-width:100%;overflow-wrap:break-word}.status-badge{font-size:.75rem;padding:.2rem .6rem}.pagination-controls{gap:.5rem;padding:.5rem}.pagination-info{font-size:.8rem}.pagination-info span{display:block;margin-bottom:.5rem}.pagination-select{font-size:.85rem;width:100%}.pagination-buttons{gap:.4rem}.pagination-btn{font-size:.8rem;min-width:60px;padding:.4rem .6rem}.pagination-btn:first-child,.pagination-btn:last-child{display:none}.pagination-page{font-size:.8rem;padding:.4rem 0}}@media (min-width:820px) and (max-width:1024px){.url-cell{max-width:350px;min-width:150px}.url-cell a{line-height:1.5;overflow-wrap:break-word;word-break:break-word}.description-cell,.title-cell{word-wrap:break-word;max-width:250px;overflow-wrap:break-word}}
/*# sourceMappingURL=main.59fd42b7.css.map*/