*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f0f0f;color:#e0e0e0;min-height:100vh;padding:2rem 1rem}.app{max-width:640px;margin:0 auto}header{margin-bottom:2rem}header h1{font-size:1.5rem;font-weight:700;color:#fff}header p{margin-top:.25rem;font-size:.875rem;color:#888}.banner-error{background:#7f1d1d;color:#fca5a5;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.add-form{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;margin-bottom:1.5rem}.input-url{flex:1 1 240px}.input-path{flex:0 1 120px}input{background:#1a1a1a;border:1px solid #333;color:#e0e0e0;border-radius:6px;padding:.5rem .75rem;font-size:.875rem}input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb66;outline:none}button{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;white-space:nowrap}button:disabled{opacity:.5;cursor:not-allowed}.btn-add:hover:not(:disabled){background:#1d4ed8}.error{color:#f87171;font-size:.8rem;width:100%}.empty{color:#555;font-size:.875rem;text-align:center;padding:2rem}.url-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.url-item{display:flex;align-items:center;gap:.75rem;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;padding:.75rem 1rem}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dot-ok{background:#22c55e}.dot-fail{background:#ef4444}.dot-pending{background:#555}.url-info{flex:1;min-width:0}.url-text{display:block;font-size:.875rem;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.url-status{display:block;font-size:.75rem;color:#888;margin-top:.125rem}.btn-delete{background:transparent;color:#555;padding:.25rem .5rem;font-size:.75rem;flex-shrink:0}.btn-delete:hover{color:#ef4444;background:transparent}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
