.api-key-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.api-key-modal{background:white;border-radius:15px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.1)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e1e5e9}.modal-header h2{color:#333;margin:0;font-size:20px}.modal-body{padding:30px}.api-info{margin-bottom:30px;padding:20px;background:#f8f9fa;border-radius:10px}.api-info p{color:#666;margin-bottom:15px;line-height:1.6}.info-steps h3{color:#333;margin-bottom:10px;font-size:16px}.info-steps ol{color:#666;padding-left:20px}.info-steps li{margin-bottom:5px;line-height:1.5}.info-steps a{color:#667eea;text-decoration:none}.info-steps a:hover{text-decoration:underline}.rate-limit-info{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:15px;margin-top:15px}.rate-limit-info h4{color:#856404;margin-bottom:10px;font-size:14px}.rate-limit-info ul{margin:0;padding-left:20px}.rate-limit-info li{color:#856404;font-size:12px;line-height:1.5;margin-bottom:5px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#333;margin-bottom:8px;font-weight:500}.api-key-input{width:100%;padding:12px 15px;border:2px solid #e1e5e9;border-radius:8px;font-size:14px;font-family:Courier New,monospace;transition:border-color .3s}.api-key-input:focus{outline:none;border-color:#667eea}.error-message{background:#fee;color:#c53030;padding:10px 15px;border-radius:8px;margin-bottom:20px;font-size:14px;border-left:4px solid #c53030}.modal-actions{display:flex;gap:15px;justify-content:flex-end}.clear-btn,.save-btn{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.clear-btn{background:#f8f9fa;color:#666;border:1px solid #e1e5e9}.clear-btn:hover{background:#e9ecef}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.save-btn:hover:not(:disabled){transform:translateY(-1px)}.save-btn:disabled{opacity:.6;cursor:not-allowed}.api-note{margin-top:20px;padding:15px;background:#e3f2fd;border-radius:8px;border-left:4px solid #2196f3}.api-note p{color:#1976d2;font-size:13px;margin:0;line-height:1.5}@media (max-width:768px){.api-key-modal{width:95%;margin:20px}.modal-header{padding:15px 20px}.modal-body{padding:20px}.modal-actions{flex-direction:column}.clear-btn,.save-btn{width:100%}}.search-section{background:white;border-radius:15px;padding:30px;margin-bottom:30px;box-shadow:0 10px 30px rgba(0,0,0,.1)}.search-header{margin-bottom:20px}.api-status{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.status-indicator.connected{color:#28a745}.status-indicator.disconnected{color:#ffc107}.api-config-btn{padding:6px 12px;background:transparent;border:1px solid #667eea;border-radius:6px;color:#667eea;font-size:12px;cursor:pointer;transition:all .2s}.api-config-btn:hover{background:#667eea;color:white}.search-form{display:flex;gap:15px;margin-bottom:20px}.search-input{flex:1 1;padding:15px;border:2px solid #e1e5e9;border-radius:10px;font-size:16px;transition:border-color .3s}.search-input:focus{outline:none;border-color:#667eea}.search-btn{padding:15px 30px;background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;border-radius:10px;cursor:pointer;font-size:16px;font-weight:600;transition:transform .2s}.search-btn:hover{transform:translateY(-2px)}.recommended-addresses{margin-top:15px}.recommended-addresses h3{color:#666;margin-bottom:10px;font-size:14px}.search-history{margin-top:15px}.search-history h3{color:#666;margin-bottom:10px;font-size:14px}.history-tags{display:flex;gap:10px;flex-wrap:wrap}.history-tag{background:#f0f2f5;padding:5px 12px;border-radius:20px;font-size:12px;color:#666;cursor:pointer;transition:background .2s}.history-tag:hover{background:#e1e5e9}.recommended-tag{background:linear-gradient(135deg,#667eea,#764ba2);color:white}.recommended-tag:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);transform:translateY(-1px)}@media (max-width:768px){.api-status,.search-form{flex-direction:column}.api-status{gap:10px;text-align:center}.api-config-btn{width:100%}}.contract-card{border:1px solid #e1e5e9;border-radius:10px;padding:20px;transition:box-shadow .3s;cursor:pointer;min-width:300px;flex-shrink:0}.contract-card:hover{box-shadow:0 5px 15px rgba(0,0,0,.1)}.contract-card.active{border-color:#667eea;box-shadow:0 5px 15px rgba(102,126,234,.2)}.contract-card h3{color:#333;margin-bottom:5px;font-size:16px;display:flex;align-items:center;gap:8px}.deployer-info{font-family:Courier New,monospace;font-size:11px;color:#666;margin-bottom:10px}.deployer-info.clickable-deployer{color:#667eea;cursor:pointer;transition:color .2s;padding:2px 4px;border-radius:3px;margin:-2px -4px 8px}.deployer-info.clickable-deployer:hover{color:#4c63d2;background-color:rgba(102,126,234,.1)}.contract-card .address{font-family:Courier New,monospace;font-size:12px;color:#666;word-break:break-all;margin-bottom:15px}.contract-card .clickable-address{color:#667eea;cursor:pointer;transition:color .2s;border-radius:4px;padding:4px 6px;margin:-4px -6px}.contract-card .clickable-address:hover{color:#4c63d2;background-color:rgba(102,126,234,.1)}.contract-stats{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.stat-item{text-align:center;padding:10px;background:#f8f9fa;border-radius:5px}.stat-value{font-size:18px;font-weight:600;color:#333}.stat-label{font-size:12px;color:#666;margin-top:5px}.verification-status{display:inline-block;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.verification-status.verified{background:#10b981;color:white}.verification-status.unverified{background:#ef4444;color:white}.proxy-badge{padding:2px 8px;border-radius:12px;font-size:11px}.implementation-info{background:#f3f4f6;padding:8px 12px;border-radius:6px;margin-bottom:12px;font-size:12px}.implementation-label{color:#6b7280;font-weight:500}.implementation-address{font-family:Courier New,monospace;color:#4b5563;margin-top:2px;font-size:11px}@media (max-width:768px){.contract-card{min-width:280px;padding:15px}.contract-card h3{font-size:14px}.contract-card .address{font-size:11px}.stat-value{font-size:16px}.stat-label{font-size:11px}}.contract-scroll-wrapper{margin-bottom:30px}.contracts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.contracts-header h2{color:#333;margin:0;font-size:24px}.scroll-controls{gap:15px}.scroll-btn,.scroll-controls{display:flex;align-items:center}.scroll-btn{width:36px;height:36px;border:2px solid #667eea;background:white;color:#667eea;border-radius:50%;cursor:pointer;font-size:16px;font-weight:700;justify-content:center;transition:all .2s}.scroll-btn:hover:not(.disabled){background:#667eea;color:white;transform:scale(1.1)}.scroll-btn.disabled{opacity:.3;cursor:not-allowed;border-color:#ccc;color:#ccc}.scroll-hint{display:flex;align-items:center}.scroll-hint span{font-size:12px;color:#888;background:#f0f2f5;padding:4px 12px;border-radius:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:.7}50%{opacity:1}}.contracts-scroll-container{display:flex;gap:20px;overflow-x:auto;padding:10px 0;scroll-behavior:smooth}.contracts-scroll-container::-webkit-scrollbar{height:8px}.contracts-scroll-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.contracts-scroll-container::-webkit-scrollbar-thumb{background:#667eea;border-radius:4px}.contracts-scroll-container::-webkit-scrollbar-thumb:hover{background:#5a6fd8}@media (max-width:768px){.contracts-header{flex-direction:column;align-items:flex-start;gap:15px}.contracts-header h2{font-size:20px}.scroll-controls{gap:10px}.scroll-btn{width:32px;height:32px;font-size:14px}.scroll-hint span{font-size:11px;padding:3px 10px}.contracts-scroll-container{gap:15px;padding:10px 5px}.contracts-scroll-container::-webkit-scrollbar{height:6px}}@media (max-width:480px){.scroll-controls{width:100%;justify-content:space-between}.scroll-hint{flex:1 1;justify-content:center}}.tab-content-wrapper{min-height:400px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px;margin-bottom:30px}.stats-card{background:#f8f9fa;padding:25px;border-radius:10px;text-align:center}.stats-card .number{font-size:32px;font-weight:700;color:#333;margin-bottom:5px}.stats-card .label{color:#666;font-size:14px}.chart-container{background:#f8f9fa;padding:20px;border-radius:10px;margin-bottom:20px;height:400px}.chart-container canvas{max-height:100%}.loading-message{display:flex;align-items:center;justify-content:center;min-height:200px;color:#666;font-size:16px;text-align:center}.contract-header{background:#f8f9fa;padding:25px;border-radius:12px;margin-bottom:25px;border:1px solid #e1e5e9;box-shadow:0 2px 8px rgba(0,0,0,.05)}.contract-title-section{display:flex;align-items:center;justify-content:space-between;margin-bottom:25px;padding-bottom:20px;border-bottom:2px solid #e9ecef}.contract-name{margin:0;color:#2c3e50;font-size:28px;font-weight:700;letter-spacing:-.5px;display:flex;align-items:baseline;gap:15px}.deployment-date{font-size:16px;font-weight:400;color:#6c757d;font-family:Courier New,monospace;letter-spacing:0}.contract-type-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:white;padding:8px 16px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px rgba(102,126,234,.3)}.contract-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:20px;gap:20px}.detail-item{background:white;padding:18px;border-radius:8px;border:1px solid #e9ecef;transition:all .2s ease}.detail-item:hover{box-shadow:0 2px 8px rgba(0,0,0,.08);transform:translateY(-1px)}.detail-label{font-size:12px;font-weight:600;color:#6c757d;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.detail-value{font-family:Courier New,monospace;font-size:13px;color:#2c3e50;font-weight:500;word-break:break-all;line-height:1.4}.detail-value.clickable-address{color:#667eea;cursor:pointer;transition:all .2s;padding:6px 10px;border-radius:6px;margin:-6px -10px;background:rgba(102,126,234,.05);border:1px solid transparent}.detail-value.clickable-address:hover{color:#4c63d2;background:rgba(102,126,234,.15);border-color:rgba(102,126,234,.2)}.verification-item .detail-value{display:flex;align-items:center}.verification-badge{padding:6px 12px;border-radius:20px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.verification-badge.verified{background:linear-gradient(135deg,#28a745,#20c997);color:white;box-shadow:0 2px 4px rgba(40,167,69,.3)}.verification-badge.unverified{background:linear-gradient(135deg,#dc3545,#e74c3c);color:white;box-shadow:0 2px 4px rgba(220,53,69,.3)}.deployment-tx-hash{position:relative;word-wrap:break-word;overflow-wrap:anywhere;white-space:normal;line-height:1.4}.contract-header h3{margin:0 0 8px;color:#333;font-size:18px;font-weight:600}.contract-address{color:#666;margin:0;word-break:break-all}.contract-address.clickable-address{color:#667eea;cursor:pointer;transition:all .2s;padding:4px 8px;border-radius:4px;margin:-4px -8px}.contract-address.clickable-address:hover{color:#4c63d2;background-color:rgba(102,126,234,.1)}.deployer-address,.deployment-time,.deployment-tx{font-family:Courier New,monospace;font-size:12px;color:#666;margin:4px 0;word-break:break-all}.deployer-address.clickable-address,.deployment-tx.clickable-address{color:#667eea;cursor:pointer;transition:all .2s;padding:4px 8px;border-radius:4px;margin:4px -8px}.deployer-address.clickable-address:hover,.deployment-tx.clickable-address:hover{color:#4c63d2;background-color:rgba(102,126,234,.1)}.function-analysis-section{margin:30px 0}.function-analysis-section h4,.type-distribution-summary h5{margin:0 0 20px;color:#333;font-size:18px;font-weight:600}.function-charts{display:grid;grid-template-columns:400px 1fr;grid-gap:30px;gap:30px;margin-bottom:30px}.pie-chart{height:300px}.function-list h5{margin:0 0 15px;color:#333;font-size:16px;font-weight:600}.function-items{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto;padding-right:8px}.function-items::-webkit-scrollbar{width:6px}.function-items::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.function-items::-webkit-scrollbar-thumb{background:#667eea;border-radius:3px}.function-items::-webkit-scrollbar-thumb:hover{background:#4c63d2}.function-item{align-items:center;padding:12px;background:#f8f9fa;border:1px solid #e9ecef}.function-rank{width:30px;height:30px;background:#667eea;color:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;margin-right:12px;flex-shrink:0}.function-details{flex:1 1;min-width:0}.function-name{font-family:Courier New,monospace;font-size:13px;font-weight:500;margin-bottom:4px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;line-height:1.4}.function-stats{display:flex;gap:8px;align-items:center}.function-count{font-size:12px;color:#666;font-weight:500}.function-percentage{font-size:12px;color:#999}.function-status{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.function-status.known{background:#d4edda;color:#155724}.function-status.unknown{background:#fff3cd;color:#856404}.type-distribution-summary{background:#f8f9fa;padding:25px;border-radius:10px;border:1px solid #e1e5e9}.stats-card .percentage{font-size:12px;color:#667eea;font-weight:600;margin-top:5px}.no-functions{text-align:center;padding:40px 20px;color:#666;font-style:italic}.chart-container h4{margin:0 0 15px;color:#333;font-size:16px;font-weight:600;text-align:center}.timeline-section{margin:30px 0}.timeline-section h4{margin:0 0 20px;color:#333;font-size:18px;font-weight:600}.timeline-chart{height:350px}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-card .number{font-size:24px}.chart-container{height:300px}.function-charts{grid-template-columns:1fr;gap:20px}.function-items{max-height:400px}.function-item{flex-direction:row;align-items:center;gap:8px}.function-rank{margin-right:8px}.function-name{font-size:12px}.contract-header{padding:20px;margin-bottom:20px}.contract-title-section{gap:15px;margin-bottom:20px}.contract-name,.contract-title-section{flex-direction:column;align-items:flex-start}.contract-name{font-size:22px;gap:8px}.deployment-date{font-size:14px}.contract-type-badge{align-self:flex-start}.contract-details-grid{grid-template-columns:1fr;gap:15px}.detail-item{padding:15px}.detail-value{font-size:12px}}.compilation-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:20px;margin-bottom:20px}.compilation-info h4{margin:0 0 15px;color:#333;font-size:16px;font-weight:600;border-bottom:2px solid #667eea;padding-bottom:8px;display:inline-block}.info-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:15px;gap:15px;align-items:start}.info-item{display:flex;flex-direction:column;gap:5px}.info-item.full-width{grid-column:1/-1}.info-label{font-size:13px;font-weight:500;color:#666;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:14px;color:#333;font-weight:500}.optimization-status{padding:4px 8px;border-radius:4px;font-size:13px;font-weight:600;display:inline-block}.optimization-status.enabled{background:#d4edda;color:#155724}.optimization-status.disabled{background:#f8d7da;color:#721c24}.optimization-runs{margin-left:8px;font-size:12px;color:#666;font-weight:400}.license-type{font-size:13px;line-height:1.4}.constructor-args,.library-info,.swarm-source{background:#ffffff;border:1px solid #dee2e6;border-radius:4px;padding:10px;margin-top:5px}.constructor-args code,.library-info code,.swarm-source code{font-family:Courier New,monospace;font-size:12px;color:#495057;word-break:break-all;line-height:1.4}.contract-address{font-size:13px}.contract-address .address-link{color:#3b82f6;text-decoration:none;padding:6px 10px;background:#eff6ff;border-radius:6px;border:1px solid #bfdbfe;display:inline-block;word-break:break-all;transition:all .2s ease}.contract-address .address-link:hover{background:#dbeafe;border-color:#93c5fd;text-decoration:none;box-shadow:0 1px 3px rgba(0,0,0,.1)}.contract-name-info{color:#1f2937;font-weight:600;background:#f3f4f6;padding:6px 10px;border-radius:4px;border:1px solid #d1d5db}@media (max-width:768px){.info-grid{grid-template-columns:1fr;gap:12px}.compilation-info{padding:15px}.compilation-info h4{font-size:15px}.info-label{font-size:12px}.info-value{font-size:13px}}.source-code-viewer{display:flex;flex-direction:column;gap:20px}.file-selector{background:#f8f9fa;border-radius:10px;padding:15px;border:1px solid #e1e5e9}.file-tabs{display:flex;gap:5px;flex-wrap:wrap}.file-tab{padding:8px 16px;background:white;border:1px solid #d1d5db;border-radius:6px;font-size:12px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.file-tab:hover{background:#f3f4f6;border-color:#9ca3af}.file-tab.active{background:#3b82f6;border-color:#3b82f6;color:white}.code-container{background:#2d3748;border-radius:10px;overflow:hidden;max-height:600px;display:flex;flex-direction:column}.code-content{flex:1 1;overflow-y:auto;min-height:0}.code-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:rgba(0,0,0,.2);color:#a0aec0;font-size:14px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.code-header-left,.code-header-right{display:flex;align-items:center;gap:15px}.file-name{font-weight:600;color:#e2e8f0}.verification-badge{background:#10b981;color:white;padding:3px 8px;border-radius:12px;font-size:11px;font-weight:600}.code-stats{color:#9ca3af;font-size:12px;font-family:Courier New,monospace}.copy-button{background:#4a5568;color:#e2e8f0;border:1px solid #718096;padding:5px 10px;border-radius:5px;font-size:11px;cursor:pointer;transition:all .2s ease}.copy-button:hover{background:#718096;border-color:#a0aec0}.source-unavailable{background:#f8f9fa;padding:40px;border-radius:10px;text-align:center}.source-unavailable h3{color:#333;margin-bottom:15px;font-size:20px}.source-unavailable p{color:#666;margin-bottom:20px;line-height:1.6}.bytecode-info{background:#e9ecef;padding:20px;border-radius:8px;margin-top:20px}.bytecode-info h4{color:#333;margin-bottom:10px;font-size:16px}.bytecode-info p{color:#666;font-family:Courier New,monospace;font-size:12px;margin-bottom:5px}.verify-tip{background:#e3f2fd;padding:15px;border-radius:8px;margin-top:20px;border-left:4px solid #2196f3}.verify-tip p{color:#1976d2;font-size:13px;margin:0;line-height:1.5;font-family:inherit}.verify-tip a{color:#1565c0;text-decoration:none;font-weight:500}.verify-tip a:hover{text-decoration:underline}.source-stats{display:flex;gap:20px;padding:15px 20px;background:#f8f9fa;border-radius:10px;border:1px solid #e1e5e9}.source-stats .stat-item{display:flex;align-items:center;gap:8px}.source-stats .stat-label{color:#666;font-size:13px;font-weight:500}.source-stats .stat-value{color:#333;font-size:13px;font-weight:600;background:white;padding:2px 8px;border-radius:12px;border:1px solid #e1e5e9}@media (max-width:768px){.source-code-viewer{gap:15px}.file-selector{padding:10px}.file-tabs{gap:3px}.file-tab{padding:6px 12px;font-size:11px;max-width:150px}.code-container{max-height:400px}.code-header{flex-direction:column;gap:10px;text-align:center;padding:12px 15px}.code-header-left,.code-header-right{gap:10px;flex-wrap:wrap;justify-content:center}.copy-button{padding:4px 8px;font-size:10px}.source-stats{flex-direction:column;gap:10px}.source-stats .stat-item{justify-content:space-between}}.wallet-connection{margin-bottom:20px}.wallet-status{display:flex;justify-content:space-between;align-items:center;padding:15px;border-radius:10px;border:1px solid #e1e5e9;background:white;gap:15px}.wallet-status.disconnected{background:#f8f9fa}.wallet-status.connected{background:#d4edda;border-color:#c3e6cb}.wallet-status.wrong-network{background:#fff3cd;border-color:#ffeaa7}.status-indicator{font-size:14px;font-weight:500;color:#333}.wallet-info{flex:1 1;display:flex;flex-direction:column;gap:5px}.wallet-address{display:flex;align-items:center;gap:10px}.wallet-balance{font-size:14px;color:#666;font-weight:500}.wallet-network{font-size:12px;color:#666}.wallet-actions{display:flex;gap:10px;align-items:center}.connect-btn{background:#667eea;color:white;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.connect-btn:hover:not(:disabled){background:#4c63d2}.connect-btn:disabled{background:#6c757d;cursor:not-allowed}.switch-network-btn{background:#ffc107;color:#212529;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s}.switch-network-btn:hover{background:#e0a800}.disconnect-btn{background:#dc3545;color:white;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:background .2s}.disconnect-btn:hover{background:#c82333}.wallet-error{margin-top:10px;padding:10px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#721c24;font-size:14px}@media (max-width:768px){.wallet-status{flex-direction:column;align-items:flex-start;gap:10px}.wallet-actions{width:100%;justify-content:flex-end}.wallet-address{flex-direction:column;align-items:flex-start;gap:5px}}.abi-tab{padding:20px}.proxy-toggle{background:#f3f4f6;border-radius:10px;padding:16px;margin-bottom:20px;border:1px solid #e5e7eb}.proxy-toggle-info{display:flex;align-items:center;gap:12px;margin-bottom:12px;font-size:14px;color:#4b5563}.proxy-badge{background:#8b5cf6;color:white;padding:4px 12px;border-radius:16px;font-size:12px;font-weight:600}.proxy-arrow{color:#9ca3af;font-size:16px}.implementation-name{font-weight:600;color:#1f2937}.proxy-toggle-buttons{display:flex;gap:8px}.toggle-button{padding:8px 16px;border:1px solid #d1d5db;background:white;border-radius:6px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s ease}.toggle-button:hover{background:#f9fafb;border-color:#9ca3af}.toggle-button.active{background:#3b82f6;border-color:#3b82f6;color:white}.implementation-info-header{background:#f8f9fa;border-radius:10px;padding:16px;margin-bottom:20px;border:1px solid #e5e7eb}.implementation-info-header h3{margin:0 0 12px;color:#1f2937;font-size:18px}.implementation-details{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.detail-item{display:flex;align-items:center;gap:8px}.detail-item .label{font-weight:600;color:#6b7280;min-width:80px}.detail-item .value{color:#1f2937}.font-mono{font-family:Courier New,monospace;font-size:13px}.address-link{color:#3b82f6;text-decoration:none;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background-color .2s}.address-link:hover{background-color:rgba(59,130,246,.1);text-decoration:underline}.notice{background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:8px 12px;font-size:13px;color:#92400e;margin-top:8px}.implementation-header{margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.implementation-header h3{margin:0 0 8px;color:#1f2937;font-size:18px}.implementation-summary{display:flex;flex-direction:column;gap:4px}.contract-name{font-weight:600;color:#374151;font-size:14px}.contract-address{font-family:Courier New,monospace;font-size:12px}.contract-address .address-link{color:#6b7280;font-size:12px}.abi-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}.abi-header h3{margin:0;color:#333}.function-filters{display:flex;gap:10px}.function-filters button{padding:8px 16px;border:1px solid #ddd;background:white;border-radius:5px;cursor:pointer;font-size:14px;transition:all .2s}.function-filters button:hover{background:#f5f5f5}.function-filters button.active{background:#667eea;color:white;border-color:#667eea}.functions-list{gap:10px}.function-item,.functions-list{display:flex;flex-direction:column}.function-item{border:1px solid #e1e5e9;border-radius:8px;overflow:hidden;position:relative}.function-item.read-only{border-left:4px solid #28a745}.function-item.write{border-left:4px solid #dc3545}.function-header{padding:15px;background:#f8f9fa;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;order:1}.function-header:hover{background:#e9ecef}.function-info{display:flex;align-items:center;gap:10px}.function-name{font-weight:600;color:#333;font-size:16px}.function-type{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase}.function-type.view{background:#d4edda;color:#155724}.function-type.pure{background:#d1ecf1;color:#0c5460}.function-type.nonpayable{background:#f8d7da;color:#721c24}.function-type.payable{background:#fff3cd;color:#856404}.function-signature{font-family:Courier New,monospace;font-size:14px;color:#666;flex:1 1;word-break:break-all}.expand-btn{width:30px;height:30px;border:none;background:#667eea;color:white;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:transform .2s}.expand-btn.expanded{transform:rotate(180deg)}.function-details{padding:20px;border-top:1px solid #e1e5e9;background:white;width:100%;box-sizing:border-box;display:block;order:2}.function-inputs h4{margin:0 0 15px;color:#333;font-size:14px}.function-input{margin-bottom:15px}.function-input label{display:block;margin-bottom:5px;font-weight:500;color:#555;font-size:14px}.unnamed-param{color:#999;font-style:italic;margin-left:5px}.input-field{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px;font-family:Courier New,monospace}.input-field:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px rgba(102,126,234,.2)}.call-button{background:#28a745;color:white;border:none;padding:12px 24px;border-radius:5px;cursor:pointer;font-size:14px;font-weight:500;margin-top:15px;transition:background .2s}.call-button:hover:not(:disabled){background:#218838}.call-button:disabled{background:#6c757d;cursor:not-allowed}.function-actions{display:flex;gap:10px;align-items:center;margin-top:15px;flex-wrap:wrap}.estimate-gas-button{background:#17a2b8;color:white;border:none;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.estimate-gas-button:hover:not(:disabled){background:#138496}.estimate-gas-button:disabled{background:#6c757d;cursor:not-allowed}.call-button.write-function{background:#dc3545}.call-button.write-function:hover:not(:disabled){background:#c82333}.gas-estimate{background:#e7f3ff;border:1px solid #bee5eb;padding:15px;border-radius:5px;margin-top:15px}.gas-estimate h5{margin:0 0 10px;color:#0c5460;font-size:14px}.gas-details{display:flex;flex-direction:column;gap:5px;font-size:13px;color:#0c5460}.transaction-info{margin-top:10px;font-size:14px}.tx-link{color:#667eea;text-decoration:none;word-break:break-all;margin-left:5px}.tx-link:hover{text-decoration:underline}.write-function-notice{background:#fff3cd;border:1px solid #ffeaa7;padding:15px;border-radius:5px;margin-top:15px}.write-function-notice p{margin:0;color:#856404;font-size:14px}.function-result{margin-top:15px;padding:15px;border-radius:5px;font-size:14px}.function-result.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.function-result.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.function-result pre{margin:10px 0 0;background:rgba(0,0,0,.05);padding:10px;border-radius:4px;font-family:Courier New,monospace;font-size:12px;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.abi-error,.no-abi,.no-functions{text-align:center;padding:40px 20px;color:#666}.abi-error p,.no-abi p,.no-functions p{margin:10px 0}@media (max-width:768px){.abi-header{flex-direction:column;align-items:flex-start}.function-filters{flex-wrap:wrap}.function-header{flex-direction:column;align-items:flex-start;gap:10px}.function-signature{font-size:12px}.expand-btn{align-self:flex-end}}.analysis-tabs{border-bottom:2px solid #e1e5e9;margin-bottom:30px}.tab-buttons{display:flex;gap:0}.tab-btn{padding:15px 25px;background:none;cursor:pointer;font-size:16px;color:#666;border:none;border-bottom:3px solid transparent;transition:all .3s;display:flex;align-items:center;gap:8px}.tab-btn.active{color:#667eea;border-bottom-color:#667eea}.tab-btn.verified .verification-checkmark{color:#28a745;font-weight:700;font-size:14px;background:rgba(40,167,69,.1);padding:2px 6px;border-radius:50%}.tab-btn.verified.active .verification-checkmark{background:rgba(40,167,69,.2)}.tab-label{flex:1 1}.tab-content{padding-top:30px}@media (max-width:768px){.tab-buttons{flex-wrap:wrap}.tab-btn{padding:10px 15px;font-size:14px;gap:6px}.tab-btn.verified .verification-checkmark{font-size:12px;padding:1px 4px}}.results-section{background:white;border-radius:15px;padding:30px;box-shadow:0 10px 30px rgba(0,0,0,.1)}.address-info{background:#f8f9fa;padding:20px;border-radius:10px;margin-bottom:30px}.address-info .address{font-family:Courier New,monospace;font-size:18px;color:#333;word-break:break-all;margin-bottom:10px}.address-info .meta{display:flex;gap:20px;color:#666;font-size:14px}@media (max-width:768px){.address-info .meta{flex-direction:column;gap:10px}}.progress-indicator{background:white;border-radius:15px;padding:30px;box-shadow:0 10px 30px rgba(0,0,0,.1);text-align:center}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.progress-message{font-size:16px;color:#333;font-weight:500}.progress-count{font-size:14px;color:#666;background:#f0f2f5;padding:4px 12px;border-radius:20px}.progress-bar{width:100%;height:8px;background:#e1e5e9;border-radius:4px;overflow:hidden;margin-bottom:20px}.progress-fill{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.progress-note{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;padding:15px;margin-top:20px}.progress-note p{margin:0;color:#856404;font-size:13px;line-height:1.5}@media (max-width:768px){.progress-header{flex-direction:column;gap:10px;text-align:center}}.usage-guide-trigger{position:fixed;bottom:20px;right:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;border-radius:50px;padding:12px 20px;font-size:14px;cursor:pointer;box-shadow:0 4px 15px rgba(102,126,234,.3);transition:transform .2s;z-index:100}.usage-guide-trigger:hover{transform:translateY(-2px)}.usage-guide-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.usage-guide-modal{background:white;border-radius:15px;width:90%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px rgba(0,0,0,.1)}.usage-guide-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;border-bottom:1px solid #e1e5e9}.usage-guide-header h2{color:#333;margin:0;font-size:20px}.close-btn{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.close-btn:hover{background:#f0f0f0}.usage-guide-content{padding:30px}.guide-section{margin-bottom:30px}.guide-section:last-child{margin-bottom:0}.guide-section h3{color:#333;margin-bottom:15px;font-size:16px}.guide-section ol,.guide-section ul{padding-left:20px}.guide-section li{color:#666;margin-bottom:8px;line-height:1.5}.guide-section a{color:#667eea;text-decoration:none}.guide-section a:hover{text-decoration:underline}@media (max-width:768px){.usage-guide-trigger{bottom:15px;right:15px;padding:10px 16px;font-size:12px}.usage-guide-modal{width:95%;margin:20px}.usage-guide-header{padding:15px 20px}.usage-guide-content{padding:20px}}