*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#1a1a1a;line-height:1.6}.container{max-width:800px;margin:0 auto;padding:3rem 1.5rem}h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.subtitle{color:#666;margin-bottom:2rem}.subtitle a{color:#2563eb;text-decoration:none}.subtitle a:hover{text-decoration:underline}.input-group{display:flex;gap:.5rem}input[type=url]{flex:1;padding:.75rem 1rem;font-size:1rem;border:2px solid #ddd;border-radius:8px;outline:none;transition:border-color .2s}input[type=url]:focus{border-color:#2563eb}button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:8px;cursor:pointer;background:#2563eb;color:#fff;transition:background .2s}button:hover{background:#1d4ed8}button.secondary{background:#e5e7eb;color:#1a1a1a}button.secondary:hover{background:#d1d5db}.error{margin-top:1rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626}.loading{text-align:center;padding:3rem 0}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;margin:0 auto 1rem;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-detail{color:#999;font-size:.875rem}.actions{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.output{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;overflow-x:auto;font-size:.875rem;line-height:1.7;white-space:pre-wrap;word-wrap:break-word}.crawl-progress{margin-top:1rem}.progress-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}.progress-count{color:#666;font-size:.875rem}.progress-bar-track{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-bar-fill{height:100%;background:#2563eb;border-radius:4px;transition:width .2s ease}.current-url{font-size:.8rem;color:#999;margin-bottom:.75rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-list{max-height:300px;overflow-y:auto;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.5rem}.url-item{padding:.25rem .5rem;font-size:.8rem;color:#444;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid #f3f4f6}.url-item:last-child{border-bottom:none}
